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IN THE UNITED STATES PATENT AND TRADEMARK OFFICE 

In re application of: Bahrs 

Serial No.: Unknown 
Filed: October 29, 1999 



For: Method and Apparatus in a Data 
Processing System For Specifying The 
Sequencing And Mediation Of Application 
Components 



PRELIMINARY AMENDMENT 

Assistant Commissioner of Patents 
Washington, D.C. 20231 

Sir: 

Prior to examination of the application, please amend the above-identified application 
as follows: 

IN THE SPECIFICATION: 

Please amend the specification as follows: 
Title: 

[Mechanism For Cross Channel Multi-Server Multi-Protocol Multi-Data Model Thin Clients] 
Method and Apparatus in a Data Processing System For Specifying The Sequencing And 
Mediation Of Application Components 



§ Group Art Unit: 2731 

§ 

§ Examiner: Unknown 

§ 

§ Attorney Docket No.: AUS990339US1 1 

§ 
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Abstract: 

[A method and apparatus of an architectural pattern for creating applications for a 
data processing system. A graphical user interface is created in which the graphical user 
interface includes a plurality of components. Processes for presenting the plurality of 
components and receiving user input are handled by a first set of graphical objects, wherein 
in response to selected user input, a first event is generated. An application object is created 
in which the application process controls an order in which the graphical objects present the 
set of components and process the event and wherein the application generates a second 
event. A transport object is created in which the transport object processes the second event 
and forwards the second event for processing to a destination within the plurality of 
destinations. A plurality of destination objects are created in which each destination object 
within the plurality of destinations objects handles accessing a destination within the plurality 
of destinations.] 

A method and apparatus in a data processing system for presenting a set of screens in 
a graphical user interface. A first screen within a set of screens is presented, wherein the set 
of screens are presented using a set of view controllers. Responsive to a selected user input 
to the first screen, an event is generated by a view controller within the set of view controllers 
identifying the user input to the first screen, which is handled by the first view controller. 
Responsive to detecting the event generated by the view controller, a second screen from the 
set of screens is selected, by an application mediator, for display by sending a response to a 
view controller handling the second screen. The application mediator is initialized from 
reading a state machine file and control processing of view event received from virtual 
controllers. 

IN THE CLAIMS: 

Please delete claims 1-264 and 296-380. 
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REMARKS 

Claims 1-264 and 296-380 have been deleted. Claims 265-295 remain in the 
application. These claims are now to be in condition for allowance. The examiner is invited 
to call the undersigned at the below-listed telephone number if in the opinion of the examiner 
such a telephone conference would expedite or aid the prosecution and examination of this 
application. 

DATE: October 29. 1999 Respectfully submitted, 
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Carstens Yee & Cahoon, LLP 
P.O. Box 802334 
Dallas, Texas 75380 
(972) 367-2001 

Attorney For Applicant 
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MECHANISM FOR CROSS CHANNEL MULTI -SERVER MULT I -PROTOCOL 
MULTI-DATA MODEL THIN CLIENTS 

BACKGROUND OF THE INVENTION 

1. Technical Field: 

The present invention relates generally to an 
improved distributed data processing system and, in 
particular to an improved method and apparatus for 
creating applications. Still more particularly, the 
present invention relates to a method and apparatus for 
creating client applications. 

2. Description of Related Art: 

Distributed data processing systems involve data 
transfers between clients and servers (also know as 
services) . Typically, a client locates a server, 
initiates a session with a server and requests the server 
to perform some service. The server expects requests 
from a client to arrive in a particular format. A 
server is more complex than a client because the server 
typically handles a large number of clients 
simultaneously, often fetches and stores information from 
a large database, creates additional transactions for 
other services, performs business logic, and returns 
information formatted according to each client channel. 

For example, data will be specified in a particular 
message format. A particular transmission protocol will 
deliver the message to the server. The server accepts 
the message protocol as its application programming model 
(API) to its services and returns a result. A variety of 
software systems, such as Enterprise Java Beans (EJB) , 
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Servlets, Java Server Pages (JSP), and XML have been 
implemented to enhance the development of client and 
server-side software. 

Client applications perform a number of different 

5 functions. For example, the application on the client 
side handles the user interface and may provide program 
logic for processing user input. Additionally, a client 
application must match the requirements of a particular 
server to provide communications with the particular 

10 server. Clients are packaged and distributed according 
to the services provided by the server. 

A graphical user interface (GUI) exists in the 
client application to handle what the user views on the 
screen. Events resulting from user input, such as mouse 

15 clicks or keyboard strokes, are detected and handled 
using "listener 7 ' processes in the application. The 
events are processed by program logic. The program logic 
may result in requests being sent to a server. 
Communication with the server is provided using processes 

20 that use protocols, such as hypertext transfer protocol 

(HTTP) , secure sockets (SSL) , or Remote Method Invocation 
(RMI) . 

Client software can be either "thick" or "thin". A 
thick client is typically a large client-installed 

25 application that may access a database directly and apply 
business logic. They typically have dependence on the 
client operating system and require manual support to 
install and configure. By contrast a thin client is 
typically a small application downloaded on request from 

30 a server and accesses the database through an 

intermediate application server. This is known as a 
multi-tier application. A number of different usage 
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scenarios for clients are present, resulting in a variety 
of client needs being present. For example, it is 
typical that in an global enterprise Intranet, the client 
configuration is controlled by the business but the large 

5 number of clients includes older machines with slow 
networks (e.g. 9600 baud). Likewise, in the Internet, 
there is little configuration control by the business and 
it is estimated that a large percentage of clients 
worldwide still use 14. 4K connections that result in very 

10 slow network speeds and downloads. A typical user will 
become very frustrated if downloads take longer than a 
minute or two. Further, mobile users require compact 
software that can be customized and packaged to fit on 
machines and operate disconnected from the network. 

15 Subsequent automated support to connect to the network is 
needed. 

At the other end of the spectrum, power users with 
high speed connections expect screen refresh times in the 
sub-second range and "instantaneous" echoing of typed 

20 characters to provide the look and feel of processing in 
a local environment. In a multi-tier computing 
environment, the primary role of the client is to present 
and gather information quickly. The client application is 
considered a business asset independent of the network 

25 topology and server function. In these environments, it 
is desirable to be able to use the same client processing 
code for different user types and interface channels, 
such as automated teller machines (ATM) , Kiosks, Internet 
[hypertext markup language (HTML)/ applets], and regional 

30 office clients (applications) . 

Consequently, a common thin or thick client 
development environment for developing clients may be 
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used to solve these problems, especially when the size 
and speed of the application download, integration and 
operation is important. Any software development 
environment should be based on sound software engineering 
principles . 

Object-oriented languages have been employed in 
creating thin clients. Object-oriented programming 
environments have been presented as providing software 
reuse, which is a desirable feature in creating thin 
clients and reducing development time. In reality, the 
present object-oriented programming environments for 
developing thin clients are unable to provide enough 
object reuse and repeatability for quickly developing 
thin clients. Nor do they specify how to readily support 
additional message formats, protocols, data models and 
servers, mobile disconnected users, and caching. 

Therefore, it would be advantageous to have an 
improved method and apparatus for a client development 
architecture that facilitates creating thin clients in a 
manner in which component reuse is increased while client 
development time is reduced, and multiple message 
formats, protocols, data models and servers, mobile 
disconnected users and caching can be readily integrated. 



5 

Docket No. AT9-99-339 

SUMMARY OF THE INVENTION 

The present invention provides an architectural 
pattern for creating applications for a data processing 

5 system. A graphical user interface is created in which 
the graphical user interface includes a plurality of 
components. Processes for presenting the plurality of 
components and receiving user input are handled by a 
first set of graphical objects, wherein in response to 

10 selected user input, a first event is generated. An 
application object is created in which the application 
process controls an order in which the graphical objects 
present the set of components and process the event and 
wherein the application generates a second event. A 

15 transport object is created in which the transport object 
processes the second event and forwards the second event 
for processing to a destination within the plurality of 
destinations. A plurality of destination objects are 
created in which each destination object within the 

20 plurality of destinations objects handles accessing a 
destination within the plurality of destinations. 

The present invention provides a method and 
apparatus in a data processing system for refreshing data 
in an application. A call is received to update data in 

25 the application, wherein the data is destined for a 

component in the application. A data type is identified 
for the data. Responsive to the data type being a handled 
data type, the data is formatted and a refresh is called 
on the component. 

30 The present invention provides a method and apparatus 

in a data processing system for displaying a component or 
container . The container is displayed within a display 



Docket No, AT9-99-339 



using a first component. A location of the component or 
container is controlled within the display using a second 
component, wherein the second component controls the 
location and geometry of the component or container in 
response to receiving an event. The component or container 
is selectively displayed using a third component, wherein 
the third component generates the event. 

The present invention provides a process in a data 
processing system for managing services in a desktop 
environment from an object oriented-environment . A 
presentation of a graphical user interface is controlled 
using a view controller, wherein the view controller 
handles user input to the graphical user interface. 
Responsive to a selected user input, the selected user 
input is sent from the view controller to an application 
mediator. Responsive to receiving the selected user 
input at the application mediator, the selected user 
input is processed at the application mediator. 
Responsive to the application mediator determining that a 
service is required in the desktop environment, an event 
is generated. Responsive to detecting the event at a 
listener object, a method is executed in the listener 
object to perform the service in the desktop environment. 

The present invention provides a method and 
apparatus in a data processing system for managing 
transactions. A request event is received at a 
transporter object. The request event includes a target 
and an indication of how to handle the request event. A 
destination object is identified within the plurality of 
destination objects using the request event to form an 
identified destination object. The request event is sent' 
to the identified destination object, wherein the 
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identified destination object handles the request using 
the indication and accesses the target. 

The present invention provides a method and 
apparatus in a data processing system for displaying a 
5 graphical user interface. A container is displayed in a 
graphical user interface from a set of containers, 
wherein a display of the container handled by a view 
controller from a set of view controllers. Each view 
controller handles the display of an associated container 

10 within the set of containers and user input for the 

associated container. A display of the set of containers 
is altered by an application mediator, wherein the set of 
containers are displayed in an order determined by the 
application mediator. 

15 The present invention provides a method and apparatus 

in a data processing system for performing validation of 
user input. User input is received in a container 
displayed in a graphical user interface/ wherein 
presentation of the container and the user input to the 

20 container are handled by a view controller. Responsive to 
receiving the user input, a call is sent to a validation 
object by the view controller. Responsive to the call, the 
validation 'object tests the user input using a criteria, 
wherein the rule is separate from the view controller, 

25 The present invention provides a method and 

apparatus in a data processing system for managing 
permissions in an application. A user input is received 
at a container handled by a view controller, wherein the 
user input requests a change in permissions in the 

30 application. This user input, may be, for example, a 
change in security in an application through a login 
process. A view event describing the user input is 
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generated. The view event is received at an application 
mediator. Responsive to receiving the view event, by the 
application mediator, a request event is generated and a 
permission corresponding to the user input is received. 
The permission alters an item, which may be in either of 
both the view controller and the application mediator. 

The present invention provides a process and 
apparatus in a data processing system for presenting a 
view to a client. At an application mediator, a view 
event is received from a view controller, wherein the 
view event describes an action on a displayed container 
handled by the view controller. Responsive to a 
requirement that a change in a placement of the displayed 
container is required, a placement event is generated by 
the application mediator. A determination is then made 
by a placement listener, as to whether the placement 
event includes an indication that an alternate view is to 
be generated. Responsive to a determination that an 
alternate view is to be generated, a call is sent to a 
method in the view controller to generate the alternate 
view. 

The present invention provides a method and 
apparatus in a data processing system for processing user 
input in a graphical user interface. A graphical user 
interface is presented using a view controller, wherein 
the view controller handles the user input to the 
graphical user interface. Responsive to a selected user 
input, an event is sent to a first application mediator . 
Responsive to the first application mediator being unable 
to process the event, the event is sent to a second 
application mediator for processing, wherein the first - 
application mediator and the second application mediator 
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handle an order in which a set of displays are displayed 
by a view controller. 

The present invention provides a method and 
apparatus in a data processing system for presenting a 
5 set of screens in a graphical user interface. A first 

screen within a, set of screens is presented, wherein the 
set of screens are presented using a set of view 
controllers. Responsive to a selected user input to the 
first screen, an event is generated by a view controller 

10 within the set of view controllers identifying the user 
input to the first screen, which is handled by the first 
view controller. Responsive to detecting the event 
generated by the view controller, a second screen from 
the set of screens is selected, by an application 

15 mediator, for display by sending a response to a view 
controller handling the second screen. 

The application mediator is initialized from reading 
a state machine file and control processing of view event 
received from virtual controllers. 

20 The present invention provides a method and 

apparatus in a data processing system for serializing 
data. A serializer receives a data element for 
serialization, wherein the data element includes a class 
name string. Responsive to receiving the data element, 

25 the serializer replaces the class name string with a code 
having a smaller size than the class name string to form 
a modified data element. Responsive to forming the 
modified data element, in which the serializer serializes 
the modified data element. This serialized data is 

30 transmitted and deserialized by a deserializer, which 
replaces the indicator with the class name. 

The present invention provides a method and 
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apparatus in a data processing system for providing an 
interface to an application for monitoring execution of 
the application. An event generated by a view controller 
is detected, wherein the view controller handles 
5 presentation of a container in a graphical user 

interface. A determination is made as to whether the 
event is an event selected for monitoring. Responsive ro 
the determination that the event is an event selected for 
monitoring, a request event is generated, wherein the 

10 request event includes data from the event and a 
destination. 

The present invention provides a method and 
apparatus for a data processing system for accessing 
classes and methods in an object oriented system. 

15 Responsive to receiving a selected user input to a 

container, a view event is sent from a view controller ro 
an application mediator. The view event identifies an 
action taken to generate the selected user input. A 
request is selectively generated based on the view ever.-, 

20 wherein the request event includes a major code 

identifying a class name as a destination and a minor 
code identifying a method name a function to be invoked. 
The request event is sent to a transporter. The 
transporter acts as a router to send the request event to 

25 an appropriate destination object from a plurality of 

destination objects. Responsive to receiving the request 
event at the transporter, the request event is sent to a 
destination object within a plurality of destination 
objects based in the class name. The destination object 

30 formats the request event into a form recognizable by the 
destination associated with the destination object. The 
destination may be located on a remote data processing 
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system. The request event is used to access the class o 
method identified in the request event. The access may 
be, for example, an invocation of the method. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

The novel features believed characteristic of the 
invention are set forth in the appended claims. The 
5 invention itself, however, as well as a preferred mode of 
use, further objectives and advantages thereof, will best 
be understood by reference to the following detailed 
description of an illustrative embodiment when read in 
conjunction with the accompanying drawings, wherein: 
10 Figure 1 depicts a pictorial representation of a 

distributed data processing system in which the present 
invention may be implemented; 

Figure 2 is a block diagram depicting a data 
processing system that may be implemented as a server in 
15 accordance with a preferred embodiment of the present 
invention; 

Figure 3 is a block diagram illustrating a data 
processing system in which the present invention may be 
implemented; 

20 Figure 4 is a diagram illustrating a model view 

controller diagram depicted in accordance with a 
preferred embodiment of the present invention; 

Figure 5 is a diagram illustrating the components in 
an architectural pattern depicted in accordance with a 
25 preferred embodiment of the present invention; 

Figure 6 is a diagram illustrating classes in a 
class hierarchy depicted in accordance with a preferred 
embodiment of the present inventions- 
Figure 7 is a unified modeling language diagram 
30 depicted in accordance with a preferred embodiment of the 
present inventions- 
Figures 8A and 8B are diagrams illustrating 
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variables and methods in a ViewController depicted in 
accordance with a preferred embodiment of the present 
invention; 

Figures 9A-9C are diagrams illustrating variables, 
constructors, and methods for ViewControllerlmpl depicted 
in accordance with a preferred embodiment of the present 
invention; 

Figures 1 OA- IOC are tables which show the variables, 
constructors and methods for ViewControllerBaselmpl 
depicted in accordance with a preferred embodiment of the 
present invention; 

Figures 11A-11C are tables which illustrate a 
variable, a constructor, and methods for a 
ViewControllerAdapter depicted in accordance with a 
preferred embodiment of the present invention; 

Figures 12A-12D are drawings illustrating variables, 
constructors, and methods for a ValidationRule depicted 
in accordance with a preferred embodiment of the present 
invention; 

Figures 13A and 13B are tables illustrating 
variables and constructors for a ValidationRuleException 
depicted in accordance with a preferred embodiment of the 
present invention; 

Figures 14A-14F are diagrams illustrating variables, 
constructors, and methods for a ViewEvent depicted in 
accordance with a preferred embodiment of the present 
invention; 

Figures ISA and 15B are diagrams illustrating a 
variable and a method for a ViewListener depicted in 
accordance with a preferred embodiment of the present 
inventions- 
Figures 16A and 16B diagrams illustrating a variable 
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and methods for an ApplicationMediator depicted in 
accordance with a preferred embodiment of the present 
invention; 

Figure 17A-17D are diagrams illustrating variables 
and a constructor for an ApplicationMediatorlmpl depicted 
in accordance with a preferred embodiment of the present 
invention; 

Figures 17E-17H are diagrams illustrating code used 
in methods for an ApplicationMediatorlmpl depicted in 
accordance with a preferred embodiment of the present 
invention; 

Figures 17I-17L are diagrams which depicts code used 
to handle the event dispatch in accordance with a 
preferred embodiment of the present invention; 

Figures 18A-18C are diagrams illustrating variables, 
constructors, and methods for a PlacementEvent depicted 
in accordance with a preferred embodiment of the present 
invention; 

Figures 19A and 19B are diagrams illustrating a 
variable and method for a PlacementListener depicted in 
accordance with a preferred embodiment of the present 
invention; 

Figures 20A-20C are diagrams illustrating variables, 
constructors, and methods for a TopEvent depicted in 
accordance with a preferred embodiment of the present 
invention; 

Figure 21A and 21B are diagrams illustrating a 
variable and methods for TopListeners depicted in 
accordance with a preferred embodiment of the present 
invention; 

Figures 22A-22C are diagrams illustrating a 
variable, constructors, and methods for RequestEvent 
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depicted in accordance with a preferred embodiment of the 
present invention; 

Figures 23A-23C are diagrams illustrating a 
variable, constructors, and methods for a 
5 RequestException depicted in accordance with a preferred 
embodiment of the present invention; 

Figures 24A and 24B are diagrams illustrating a 
variable and methods for a RequestListener depicted in 
accordance with a preferred embodiment of the present 
10 invention; 

Figures 25A and 25B are diagrams illustrating a 
variable and methods for a RequestResponseListener 
depicted in accordance with a preferred embodiment of the 
present invention; 
15 Figures 26A-26C are diagrams illustrating variables, 

a constructor, and methods for a Transporter depicted in 
accordance with a preferred embodiment of the present 
invention; 

Figures 26D-26G are diagrams illustrating code used 
20 in methods in a Transporter depicted in accordance with a 
preferred embodiment of the present invention; 

Figures 27A and 27B are diagrams illustrating a 
variable and methods for a Destination depicted in 
accordance with a preferred embodiment of the present 
25 invention; 

Figures 28A-28C are diagrams illustrating variables, 
constructors, and methods for a Destinationlmpl depicted 
in accordance with a preferred embodiment of the present 
invention; 

30 Figure 28D is code used to process a RequestEvent 

depicted in accordance with a preferred embodiment of the 
present invention; 
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Figures 29A and 29B are diagrams illustrating 
variables and methods in a Factory depicted in accordance 
with a preferred embodiment of the present invention; 
Figures 30A and 30B are diagrams illustrating a 
5 variable and methods for a JTC depicted in accordance 
with a preferred embodiment of the present invention; 

Figure 31 is a flowchart of a process for creating a 
ViewController depicted in accordance with a preferred 
embodiment of the present invention; 
10 Figure 32 is a flowchart of a process for creating 

ValidationRules depicted in accordance with a preferred 
embodiment of the present invention; 

Figure 33 is a flowchart of a process for creating a 
ViewEvent depicted in accordance with a preferred 
15 embodiment of the present inventions- 
Figure 34 is a flowchart of a process to create an 
ApplicationMediator depicted in accordance with a 
preferred embodiment of the present inventions- 
Figure 35 is a flowchart of a process for creating a 
20 RequestEvent depicted in accordance with a preferred 
embodiment of the present inventions- 
Figure 36 is a flowchart of a process for creating a 
Destination depicted in accordance with a preferred 
embodiment of the present invention; 
25 Figure 37 is a flowchart of a process for creating a 

TopListener depicted in accordance with a preferred 
embodiment of the present inventions- 
Figure 38 is a flowchart of a process for creating a 
PlacementListener depicted in accordance with a preferred 
30 embodiment of the present invention; 

Figure 39 is a diagram illustrating runtime behavior 
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of a ViewController subsystem depicted in accordance with 
a preferred embodiment of the present invention; 

Figure 40 are steps in the operation of a 
ViewController subsystem, as viewed from a 
5 ViewControllerlmpl, depicted in accordance with a 
preferred embodiment of the present inventions- 
Figure 41 is a flowchart of a process for a JTC 
application to present alternate views (HTML/XML) of 
itself while running in a separate environment, such as a 
10 server, as the alternate views depicted in accordance 
with a preferred embodiment of the present inventions- 
Figures 42 and 43 are diagrams detailing processes 
within the ViewController subsystem depicted in 
accordance with a preferred embodiment of the present 
15 inventions- 
Figure 44 is a complete list of predefined major 
event codes depicted in accordance with a preferred 
embodiment of the present inventions- 
Figure 44 shows how a text field representing a 
20 social security number can be validated and displayed 

depicted in accordance with a preferred embodiment of the 
present invention; * 

Figure 46 shows how a social security number can be 
validated and converted back to a transmittable format 
25 depicted in accordance with a preferred embodiment of the 
present invention; 

Figure 47 illustrates the application of two edit 
rules, range checking, and formatting for viewing 
depicted in accordance with a preferred embodiment of the 
30 present invention; 

Figure 48 illustrates inheritance where the 
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ViewControllerBaselmpl is a subclass of JPanel from the 
Java swing components depicted in accordance of a 
preferred embodiment of the present invention; 

Figure 49 illustrates inheritance where the 
5 ViewControllerBaselmpl is a subclass of java. lang. Object 
and where the methods getComponent, setEnabled and 
setVisible are implemented to ensure the ViewController 
subclassing ViewControllerBaselmpl can be treated as a 
GUI component, container or bean depicted in accordance 
10 of a preferred embodiment of the present invention; 

Figure 50 is a diagram illustrating runtime behavior 
of an ApplicationMediator subsystem depicted in 
accordance with a preferred embodiment of the present 
invention; 

15 Figure 51 is a diagram illustrating Event threading 

support depicted in accordance with a preferred embodiment 

of the present invention; 

Figure 52 is a flowchart of a process used in 

designing and executing an ApplicationMediator depicted in 
20 accordance with a preferred embodiment of the present 

inventions- 
Figure 53 is a diagram illustrating runtime behavior 

of the Placement subsystem is depicted in accordance with 

a preferred embodiment of the present invention; 
25 Figure 54 is Java code illustrating the creation and 

firing of a PlacementEvent in an ApplicationMediator 

depicted in accordance with a preferred embodiment of the 

present inventions- 
Figure 55 is Java code illustrating the callback to 
30 a PlacementListener with a PlacementEvent and inspecting 

the PlacementEvent for semantic interpretation depicted 
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in accordance with a preferred embodiment of the present 
invention; 

Figure 56 is a flowchart of a process used in 
processing a PlacementEvent depicted in accordance with a 
5 preferred embodiment of the present invention; 

Figure 57 is a diagram illustrating runtime behavior 
for a TopListener subsystem depicted in accordance with a 
preferred embodiment of the present invention; 

Figure 58 is Java code illustrating the creation of 
10 an ApplicationMediator and the adding of a 

PlacementListener depicted in accordance with a preferred 
embodiment of the present inventions- 
Figure 59, is Java code illustrating the creation 
and firing of a TopEvent in an ApplicationMediator 
15 depicted in accordance with a preferred embodiment of the 
present invention; 

Figure 60 is Java code illustrating the callback to 
a TopListener with a TopEvent and inspecting the TopEvent 
for semantic interpretation depicted in accordance with a 
20 preferred embodiment of the present inventions- 
Figure 61 is a diagram illustrating runtime behavior 
of a RequestEvent subsystem depicted in accordance with a 
preferred embodiment of the present invention; 

Figure 62 is Java code illustrating the creation of 
25 RequestEvent, setting its major and minor codes, and 
firing an asynchronous RequestEvent from an 
ApplicationMediator depicted in accordance with a 
preferred embodiment of the present invention; 

Figure 63 is Java code illustrating the callback, to 
30 an ApplicationMediator, a successful asynchronous 

RequestEvent with a result depicted in accordance with a 



20 

Docket No. AT9-99-339 



preferred embodiment of the present invention; 

Figure 64 is Java code illustrating the callback, to 
an ApplicationMediator, an unsuccessful asynchronous 
RequestEvent with a RequestException depicted in 
5 accordance with a preferred embodiment of the present 
invention; 

Figure 65 is a flowchart of a process for using a 
RequestEvent depicted in accordance with a preferred 
embodiment of the present invention; 

10 Figure 66 is a diagram illustrating runtime behavior 

of a Transporter subsystem depicted in accordance with a 
preferred embodiment of the present invention; 

Figure 67 is Java code illustrating creation of a 
Transporter and adding it as a RequestListener depicted in 

15 accordance with a preferred embodiment of the present 
invention; 

Figure 68 is runtime behavior of a Destination 
subsystem shown in accordance with a preferred embodiment 
of the present invention; 
20 Figure 69 is a diagram of Java code for creation of a 

Destination, setting a major code and adding it to a 
Transporter as a DestinationListener depicted in 
accordance with a preferred embodiment of the present 
invention; 

25 Figure 70 is a diagram illustrating Java code for 

creating Destinations with wild card, priority and normal 
major codes, firing a RequestEvent, and a report of the 
expected results depicted in accordance with a preferred 
embodiment of the present invention; 

30 Figure 71 is a diagram of Java code used for 

accessing, identifying type and recursively attaching JTC, 
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AWT and JFC listeners to JTC, AWT and JFC programs and 
objects depicted in accordance with a preferred 
embodiment of the present invention; 

Figure 72 is a diagram of Java code used for 
attaching JTC listeners to JTC ApplicationMediators, 
ViewControllers and Transporters depicted in accordance 
with a preferred embodiment of the present invention; 

Figure 73 is a diagram of Java code used for 
attaching AWT and JFC listeners to AWT and JFC containers, 
components and beans depicted in accordance with a 
preferred embodiment of the present invention; 

Figure 74 is a diagram of Java code used for 
attaching AWT and JFC listeners to AWT and JFC components 
(java. awt .Button, com. sun. swing . j ava . JBut ton and com. and 
com.sun. java. swing. JTextField) depicted in accordance with 
a preferred embodiment of the present inventions- 
Figure 75 is a flowchart of a process for for 
performing hookJTCs and hookAWTs, non intrusive tracing, 
hooking, debugging, monitoring and logging of JTC programs 
and JTC program objects depicted in accordance with a 
preferred embodiment of the present inventions- 
Figure 76 is a diagram describing the relationship 
between components and containers depicted in accordance 
with a preferred embodiment of the present invention; 

Figure 77 is a flowchart of a process for performing 
hookAWTs depicted in accordance with the preferred 
embodiment of the present invention; 

Figure 78 is a process for hooking an AWT and JFC 
component depicted in accordance with the preferred 
embodiment of the present invention; 

Figures 79-82 are diagrams of Java code for use in 
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managing the refresh of data objects in an 
ApplicationMediator (79), managing the refresh of data 
objects in a ViewController using initial types (80), and 
managing the refresh of data objects in a ViewController 

5 using an multiple concurrent updated or additional data 
types (81, 82) depicted in accordance with a preferred 
embodiment of the present invention; 

Figure 83 is a diagram of using multiple concurrent 
data model update notification mechanisms in a 

10 ViewController and ApplicationMediator depicted in 

accordance with a preferred embodiment of the present 
invention; 

Figure 84 is a flowchart of a process used in a 
TopListener depicted in accordance with a preferred 
15 embodiment of the present invention; 

Figure 85 is a flowchart of a PlacementListener 
depicted in accordance with a preferred embodiment of the 
present invention; 

Figure 86 is a flowchart illustrating handling of 
20 AWTEvents by a ViewController depicted in accordance with 
a preferred embodiment of the present invention; 

Figure 87 is a flowchart illustrating application of 
ValidationRules depicted in accordance with a preferred 
embodiment of the present invention; 
25 Figure 88 is a flowchart of a process for firing a 

ViewEvent depicted in accordance with a preferred 
embodiment of the present invention; 

Figures 89-95 are flowcharts illustrating processes 
used by an ApplicationMediator depicted in accordance 
30 with a preferred embodiment of the present invention; 
Figures 96 and 97 are diagrams illustrating 
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processes used to refresh object data in an 
ApplicationMediator and ViewController depicted in 
accordance with a preferred embodiment of the present 
invention; 

5 Figure 98 is a flowchart of a process used to 

process RequestEvents depicted in accordance with a 
preferred embodiment of the present invention; 

Figure 99 is a flowchart of an initialization 
process for creating hierarchical ApplicationMediators 
10 depicted in accordance with a preferred embodiment of the 
present invention; 

Figure 100 is a flowchart of a process for handling 
events in a hierarchical ApplicationMediator system 
depicted in accordance with a preferred embodiment of the 
15 present invention; 

Figure 101 is a flowchart for a process for building 
a virtual ApplicationMediator state dispatching machine 
depicted in accordance with a preferred embodiment of the 
present invention; 
20 Figure 102 illustrates example table entries from 

the loading of a configuration file for a virtual 
ApplicationMediator state machine depicted in accordance 
of a preferred embodiment of the present inventions- 
Figures 103 and 104 are virtual ApplicationMediator 
25 access state dispatching machine used to determine 

whether processing of a ViewEvent is needed depicted in 
accordance with a preferred embodiment of the present 
invention; 

Figure 105 is a diagram of a serializer system write 
30 depicted in accordance with a preferred embodiment of the 
present invention; 
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Figure 106 is a diagram of a serializer system read 
depicted in accordance with a preferred embodiment of the 
present invention; 

Figure 107 is a diagram illustrating an object array 
5 depicted in accordance with a preferred embodiment of the 
present invention; 

Figure 108 is a diagram illustrating code used in a 
serialization method depicted in accordance with a 
preferred embodiment of the present invention; 
10 Figure 109 implements the methods readExternal and 

writeExternal for reading/writing from/to input/output 
stream depicted in accordance of a preferred embodiment 
of the present invention; 

Figure 110 is a diagram illustrating code used in a 
15 serialization method depicted in accordance with a 
preferred embodiment of the present inventions- 
Figure 111 is a flowchart of a process for using a 
serializer depicted in accordance with the preferred 
embodiment of the present invention; 
20 Figure 112 is a flowchart of a process for 

statically creating matching user profiles and associated 
JTC permission keys for JTC programs, where keys are 
built by recursively querying JTC ApplicationMediator and 
ViewController objects, depicted in accordance with a 
25 preferred embodiment of the present invention; 

Figure 113 is a flowchart of a process for a JTC 
program building a database of permission keys by 
iterating over JTC ApplicationMediator' s getPermissions 
method and returning permission keys that are 
30 ViewController names that are alterable at runtime 

depicted in accordance with a preferred embodiment of the 
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present invention; 

Figure 114 is a flowchart of a process for a JTC 
ApplicationMediator building a database of permission 
keys by iterating over JTC ViewController' s 
5 getPermissions method and returning permission keys that 
are names known only to the ViewController and hat are 
alterable at runtime depicted in accordance with a 
preferred embodiment of the present invention; 

Figure 115 is a flowchart of a process for a JTC 
10 ViewController building a database of permission keys by 
iterating over runtime alterable components, containers 
and beans and returning permission keys that are 
component, container or bean names that are alterable at 
runtime depicted in accordance with a preferred 
15 embodiment of the present invention; 

Figures 116 is a flowchart of a process for a JTC 
program accepting a database of permission keys by 
retrieving permission key/value data supplying the data 
to a JTC program depicted in accordance with a preferred 
20 embodiment of the present inventions- 
Figure 117 is a flowchart of a process for a JTC 
program supplied with a setting of permission key/value 
data and iterating over all ApplicationMediators and 
passing the key/value data through setPermissions 
25 depicted in accordance with a preferred embodiment of the 
present invention; 

Figure 118 is a flowchart of a process for a JTC 
ApplicationMediator called with setPermissions of 
permission key/value data and iterating over all 
30 ViewControllers and passing the key/value data through 
setPermissions depicted in accordance with a preferred 
embodiment of the present invention; 
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Figure 119 is a flowchart of a process for a JTC 
ViewController called with setPermissions of permission 
key/ value data and iterating over the permission keys, 
identifying the corresponding components, containers and 
beans, and applying the value to the components, 
containers and beans, depicted in accordance with a 
preferred embodiment of^the present invention; and 

Figures 120-123 illustrate example patterns using 
the architectural pattern of the present invention 
depicted in accordance of a preferred embodiment of the 
present invention . 
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DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT 
I . Hardware 

With reference now to the figures, Figure 1 depicts a 
5 pictorial representation of a distributed data processing 
system in which the present invention may be implemented. 
Distributed data processing system 100 is a network of 
computers in which the present invention may be 
implemented. Distributed data processing system 100 

10' contains a network 102, which is the medium used to 

provide communications links between various devices and 
computers connected together within distributed data 
processing system 100. Network 102 may include permanent 
connections, such as wire or fiber optic cables, or 

15 temporary connections made through telephone connections. 

In the depicted example, a server 104 is connected to 
network 102 along with storage unit 106. In addition, 
clients 108, 110, and 112 also are connected to a network 
102. These clients 108, 110, and 112 may be, for example, 

20 personal computers or network computers. For purposes of 
this application, a network computer is any computer, 
coupled to a network, which receives a program or other 
application from another computer coupled to the network. 
In the depicted example, server 104 provides data, such as 

25 boot files, operating system images, and applications to 
clients 108-112. Clients 108, 110, and 112 are clients to 
server 104. Distributed data processing system 100 may 
include additional servers, clients, and other devices not 
shown. In the depicted example, distributed data 

30 processing system 100 is the Internet with network 102 
representing a worldwide collection of networks and 
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gateways that use the TCP/IP suite of protocols to 
communicate with one another. At the heart of the 
Internet is a backbone of high-speed data communication 
lines between major nodes or host computers, consisting of 
5 thousands of commercial, government, educational and other 
computer systems that route data and messages. Of course, 
distributed data processing system 100 also may be 
implemented as a number of different types of networks, 
such as for example, an intranet, a local area network 

10 (LAN) , or a wide area network (WAN) . Figure 1 is intended 
as an example, and not as an architectural limitation for 
the present invention. 

Referring to Figure 2, a block diagram depicts a data 
processing system that may be implemented as a server, 

15 such as server 104 in Figure 1, in accordance with a 
preferred embodiment of the present invention. Data 
processing system 200 may be a symmetric multiprocessor 
(SMP) system including a plurality of processors 202 and 
204 connected to system bus 206, Alternatively, a single 

20 processor system may be employed. Also connected to 
system bus 206 is memory controller/cache 208, which 
provides an interface to local memory 209, I/O bus bridge 
210 is connected to system bus 206 and provides an 
interface to I/O bus 212. Memory controller/cache 208 and 

25 I/O bus bridge 210 may be integrated as depicted. 

Peripheral component interconnect (PCI) bus bridge 
214 connected to I/O bus 212 provides an interface to PCI 
local bus 216. A number of modems may be connected to PCI 
bus 216. Typical PCI bus implementations will support 

30 four PCI expansion slots or add-in connectors. 

Communications links to network computers 108-112 in 
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Figure 1 may be provided through modem 218 and network 
adapter 220 connected to PCI local bus 216 through add-in 
boards . 

Additional PCI bus bridges 222 and 224 provide 
5 interfaces for additional PCI buses 226 and 228, from 
which additional modems or network adapters may be 
supported. In this manner, server 200 allows connections 
to multiple network computers* A memory-mapped graphics 
adapter 230 and hard disk 232 may also be connected to I/O 
10 bus 212 as depicted, either directly or indirectly. 

Those of ordinary skill in the art will appreciate 
that the hardware depicted in Figure 2 may vary. For 
example, other peripheral devices, such as optical disk 
drives and the like, also may be used in addition to or in 
15 place of the hardware depicted. The depicted example is 
not meant to imply architectural limitations with respect 
to the present invention. 

The data processing system depicted in Figure 2 may 
be, for example, an IBM RISC/System 6000 system, a product 
20 of International Business Machines Corporation in Armonk, 
New York, running the Advanced Interactive Executive (AIX) 
operating system. 

With reference now to Figure 3, a block diagram 
illustrates a data processing system in which the present 
25 invention may be implemented. Data processing system 300 
is an example of a client computer. Data processing 
system 300 employs a peripheral component interconnect 
(PCI) local bus architecture. Although the depicted 
example employs a PCI bus, other bus architectures such as 
30 Micro Channel and Industry Standard Architecture (ISA) may 
be used. Processor 302 and main memory 304 are connected 
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to PCI local bus 306 through PCI bridge 308. PCI bridge 
308 also may include an integrated memory controller and 
cache memory for processor 302. Additional connections to 
PCI local bus 306 may be made through direct component 

5 interconnection or through add-in boards. In the depicted 
example, local area network (LAN) adapter 310, Small 
Computer System Interface host bus adapter 312, and 
expansion bus interface 314 are connected to PCI local bus 
306 by direct component connection. In contrast, audio 

10 adapter 316, graphics adapter 318, and audio/video adapter 
319 are connected to PCI local bus 306 by add-in boards 
inserted into expansion slots. Expansion bus interface 
314 provides a connection for a keyboard and mouse adapter 
320, modem 322, and additional memory 324. Small computer 

15 system interface (SCSI) host bus adapter 312 provides a 
connection for hard disk drive 326, tape drive 328, and 
CD-ROM drive 330. Typical PCI local bus implementations 
will support three or four PCI expansion slots or add-in 
connectors . 

20 An operating system runs on processor 302 and is used 

to coordinate and provide control of various components 
within data processing system 300 in Figure 3. The 
operating system may be a commercially available operating 
system such as OS/2, which is available from International 

25 Business Machines Corporation. "OS/2" is a trademark of 
International Business Machines Corporation. An object 
oriented programming system such as Java may run in 
conjunction with the operating system and provides calls 
to the operating system from Java programs or applications 

30 executing on data processing system 300. "Java" is a 

trademark of Sun Microsystems, Inc. Instructions for the 
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operating system, the object-oriented operating system, 
and applications or programs are located on storage 
devices, such as hard disk drive 326, and may be loaded 
into main memory 304 for execution by processor 302. 

5 Those of ordinary skill in the art will appreciate 

that the hardware in Figure 3 may vary depending on the 
implementation. Other internal hardware or peripheral 
devices, such as flash ROM (or equivalent nonvolatile 
memory) or optical disk drives and the like, may be used 

10 in addition to or in place of the hardware depicted in 
Figure 3. Also, the processes of the present invention 
may be applied to a multiprocessor data processing 
system. 

For example, data processing system 300, if 

15 optionally configured as a network computer, may not 

include SCSI host bus adapter 312, hard disk drive 326, 
tape drive 328, and CD-ROM 330, as noted by dotted line 
332 in Figure 3 denoting optional inclusion. In that 
case, the computer, to be properly called a client 

20 computer, must include some type of network communication 
interface, such as LAN adapter 310, modem 322, or the 
like. As another example, data processing system 300 may 
be a stand-alone system configured to be bootable without 
relying on some type of network communication interface, 

25 whether or not data processing system 300 comprises some 
type of network communication interface. As a further 
example, data processing system 300 may be a Personal 
Digital Assistant (PDA) device which is configured with 
ROM and/or flash ROM in order to provide nonvolatile 

30 memory for storing operating system files and/or 
user-generated data. 

The depicted example in Figure 3 and above-described 
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examples are not meant to imply architectural 
limitations. For example, data processing system 300 
also may be a notebook computer or hand held computer in 
addition to taking the form of a PDA. Data processing 
5 system 300 also may be a kiosk or a Web appliance. 

II . Overview 

With reference next to Figure 4, a diagram 
illustrating a model view controller diagram is depicted 
10 in accordance with a preferred embodiment of the present 
invention. Model view control (MVC) diagram 400 includes 
an end-to-end section 402 in which the view is 
represented by client 404, the control is represented by 
mid-tier logic 406 and the model is represented by 
15 persistence storage 408. Section 410 is a graphical user 
interface (GUI) component architecture in which the view 
are Java components 412, the control are event listeners 
414, and the model are Java models 416. GUI components 
410 may be currently embodied in systems such as the Java 
20 Foundation Classes (JFC) from Java. 

In accordance with a preferred embodiment of the 
present invention, the present invention provides an 
architectural pattern for views in the client, for 
naviagation of views in the client, for placing and 
25 presenting views in a client, for issuing requests for 
different concurrent servers and services from the 
client, for issuing requests for client platform services 
from the client, for using multiple concurrent data model 
types in the client, for issuing multiple message 
30 formats from the client, for using multiple protocols in 
the client and for specific partitioning of these pattern 
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components in the client, such as client 404. In 
particular, section 418 in these examples significantly 
defines and enhances and includes a view as Java Abstract 
Windows Toolkit (AWT)/(JFC) 420, a control as screen 

5 control 422, and a model as transactions 424. AWT is a 
tool kit containing primitives for basic windowing 
functionality. These primitives include user interface 
functionality, such as window and dialogue box 
manipulations, text rendering, buttons, check box, and 

10 radio button creation and manipulation, as well as 

graphics primitives such as line drawing, color choice. 
Virtually all sophisticated graphics and user-interface 
tools are built upon these primitives. The Java 
foundation classes (JFC) is a package containing, among 

15 other things, primitives for windowing functionality that 
provide a rich superset of AWT. These primitives or 
components include everything that the AWT provides along 
with a rich superset of new primitives, including, for 
example, tree view, tabbed panes, hypertext markup 

20 language (HTML) text views, etc. Java AWT/ (JFC) 420 
could be described through section 410. 

Object-oriented design depends heavily on the class 
concept and the relationships between various classes. A 
class is an abstraction of an object that contains both 

25 attributes (data) and behavior (methods) . Each new 

object created from a class is referred to as an instance 
of that class. In other words, the class is an abstract 
encapsulation mechanism while an instance is a particular 
object created from the class. If a method in a class is 

30 called, it is sometimes said a message is sent to an 
object. 

Classes are organized into inheritance hierarchies 
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where a parent class may have one or several subclasses. 
The subclasses share all the data and methods from the 
parent class and any other ancestor class in the 
inheritance tree. The search for the appropriate methods 
to be used starts at the class for the object and 
proceeds up the tree as necessary to find the desired 
method (the name and parameters of the method must match 
exactly) . Multiple inheritance means that a class can 
have two or more parent classes. Some programming 
languages (e.g., C++) support multiple inheritance while 
others (e.g., Smalltalk) do not. Multiple inheritance is 
difficult to manage, so some languages (e.g., Java) 
provide a mechanism called interfaces that provide a type 
oriented mechanism to achieve a similar functionality 
without incurring the implementation burdens. The class 
hierarchy diagram is based on a Java implementation and 
makes extensive use of the interface mechanism. 

III. Architectural Pattern 

The present invention provides a method, apparatus, 
and instructions for an architectural programming pattern 
and implementation. The architectural pattern of the 
present invention is illustrated as a Java implementation 
for building thin (or thick) client applications and is 
also referred to as "JTC." JTC is a process, 
architectural pattern, and implementation to guide 
developers on how to build applications, and in 
particular, Internet style thin clients. JTC adapts to 
Internet changes rapidly. JTC increases developer 
discipline by providing a common repeatable programming 
pattern. JTC facilitates project management by providing 
for concurrent development of the client. JTC 
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facilitates project management by providing for 
concurrent client and server (s) development- JTC 
provides for a natural partition of various programmer 
skills, JTC has a formula based approach for cost 
5 estimates. JTC provides multi-channel support (ATM, 

Internet, Kiosk, Extranet, Mobile, Branch, Call Center, 
Business partners, etc.). JTC supports mobile user 
disconnected mode. JTC provides natural support for 
multiple servers with reduced code level cohesion and 
10 coupling. JTC provides natural support for multiple data 
models such as, for example, XML, DHTML, Objects, 
Key/Value, EJB, streaming and asynchronous. JTC has 
natural support for multiple protocols, such as, for 
example HOP, RMI, Sockets, HTTP, HTTPs, and Files. JTC 
15 has natural support for client Java accessible RS232 
devices and APIs such as currency counters, J/XFS, 
printers, and coin dispensers. 

With reference now to Figure 5, a diagram 
illustrating the components in an architectural pattern 
20 is depicted in accordance with a preferred embodiment of 
the present invention. Architectural pattern 500 
includes a ViewController 502, which provides a display 
of a component, container or bean on a data processing 
system. ViewController 502 basically provides a reusable 
25 GUI element containing graphical components such as text 
fields, labels, buttons, tables, images, beans, etc. to 
be displayed for viewing and interacting by a user. 
ValidationRules 504 are used to validate and format the 
user entry into components contained within the 
30 ViewController. For example, ValidationRules 504 may be 
applied to a single text field or to groups of text 
fields used for user entry. If a violation of a rule 
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occurs, ValidationRuleException 506 is generated. 

User inputs occur on the components, containers and 
beans controlled by ViewController 502. This user input 
is in the form of an AWTEvent 508 in the depicted 
5 examples. The AWTEvent 508 may be, for example, the 

click of a mouse button selecting a graphical button such 
as an "okay" button. In # response, ViewController 502 
will fire ViewEvent 510. ViewEvent 510 will contain 
major and minor codes that add more semantics than the 
10 AWTEvent 508. The changed data that may have been 

modified or entered by user or a reference to the data 
model may also be supplied for further semantics. 
AWTEvents 508 are not visible outside of the 
] 0 ViewController 502. 

hj 15 Next in architectural pattern 500, 

l ~Z ApplicationMediator 512 is a form of a ViewListener in 

111 the depicted examples. ApplicationMediator 512 is the 

7* interface used to specify default behavior to control 

H ViewController 502 as well as other ApplicationMediators 

py 20 512. ApplicationMediator 512 will also mediate between 

[ % ViewController 502 generated ViewEvents 510 and 

Cf PlacementListener 514, TopListener 516 and Transporter 

524. In this pattern, PlacementListener 514 is employed 
to manage the placement/containment of ViewControllers, 
25 such as ViewController 512 on the screen of a computer. 
PlacementListener 514 will manage ViewController 502 in 
response to a PlacementEvent 518 received from 
ApplicationMediator 512. For example, for a given 
component, container or bean represented by 
30 ViewController 502, PlacementListener 514 will control 
how ViewController 502 is placed on a screen, such as 
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possibly in the south of a frame with a border layout. 

ApplicationMediator 512 controls the ordering of 
ViewControllers, not the placement of ViewControllers . 
As a result, complete separation between view creation 
5 and layout by ViewController 502, view ordering and 

mediation by ApplicationMediator 512, and view placement 
by PlacementListener 514 is provided. This mechanism in 
architectural pattern 500 increases the reusability of 
ViewControllers, ApplicationMediators, and 
10 PlacementListeners . PiacementEvent 518 is used to notify 
PlacementListener 514 if ViewController needs to be 
adjusted on the screen. 

Next, TopListener 516 is an interface that performs 
specific desktop duties, such as, for example, the 
15 launching of an application, performing a desktop 

shutdown, displaying a message on the desktop, displaying 
a context sensitive title on the desktop or reconfiguring 
and non-intrusive observing the JTC application. 
TopEvent 520 is used to send a message to the TopListener 
20 to indicate that some action is needed on the desktop. 
A desktop provides the operating-specific 
functionality of a windowing system and application 
management. For example, in Windows 95, the graphical 
interface that starts up is called a "desktop". The 
25 Windows 95 GUI itself is the "desktop system". 

Additionally, a desktop application provides a view or 
window in which an application may run and launch other 
applications. This is typically accomplished by a 
display of a hierarchical list of applications, which 
30 may be selected and "launched". 

ApplicationMediator 512 may generate and receive 
RequestEvents, such as RequestEvent 522. A RequestEvent, 
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as used herein, represents a "lightweight transaction" 
that is used as an indication that an event and a service 
is required to process the event. A RequestEvent 522 is 
identified by major and minor codes. In addition, a 
reference to a data model may be included for additional 
semantics* In turn, Transporter 524 in architectural 
pattern 500 is used to map RequestEvents, such as 
RequestEvent 522, to Destinations 528, 530, and 532. In 
other words, Transporter 524 acts as an event broadcast 
mechanism within architectural pattern 500. Transporter 
524 will route RequestEvents, such as RequestEvent 526 to 
various Destinations, such as Destination 528, 
Destination 530, or Destination 532. These destinations 
will interpret the RequestEvent 526, locate a server, 
create a message format, create a protocol and deliver 
the information to the server's service for processing. 
These response data will be returned to the Transporter 
524 in a RequestEvent, such as RequestEvent 526. In 
turn, Transporter 524 will return the RequestEvent to 
ApplicationMediator 512, which will process the data 
contained in the event accordingly. For example, the 
return data may be sent to ViewController 502 to refresh 
the view displayed on the screen to the user. If an 
error occurs, a RequestException 534 may be generated and 
returned to Transporter 524 and returned to the 
ApplicationMediator 512 . 

The ApplicationMediator 512 can fire RequestEvents 
to the Transporter synchronously, asynchronously and 
repeating asynchronously. A synchronous RequestEvent 
will block the ApplicationMediator and either an error 
RequestException will be thrown or a possibly modified 
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RequestEvent will contain the results. An asynchronous 
RequestEvent will return immediately. The error 
RequestException or a possibly modified RequestEvent will 
later be "called back" to the ApplicationMediator at the 
5 requestException and requestResponse interface, 

respectively. 

In depicted examples, a type Object data, such as 
Data 5^6 may be passed in reference by ViewController 502 
to a Destination such as Destination 1 528, This data is 

10 passed via different events, such as ViewEvent 510, 

RequestEvent 522, and RequestEvent 526. Changed data, 
such as Data 538 may be returned from a Destination to 
ViewController 502 for display. This type Object data 
may take various forms, such as Extensible Markup 

15 Language (XML) , String, Hypertext Markup Language (HTML) , 
key/value, Remote Method Invocation (RMI ) , J/XFS, RS232, 
etc. The ViewController reads and modifies the Object 
data but does not create the data and the Destination 
creates, reads and modifies the Object data and sends it 

20 to and receives it from a server. 

In addition, architectural pattern 500 also includes 
a Factory 540, which is used to allocate objects. 
Factory 542 is employed to also allocate singleton 
objects . 

25 JTC 544 the system also contains a JTC interface 

implemented by all major objects in a JTC application 
including ApplicationMediator, ViewController, 
Destination and Transporter. Together, the objects 
implementing the JTC interface give the external 

30 appearance of a single application as they implement and 
propagate the required JTC interface methods. 

The architectural pattern separates ViewController 
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502 (GUI view) from ApplicationMediator 512 (GUI state 
transition) from PlacementListener 514 (GUI placement) 
from RequestEvent 522 (lite transaction) creation from 
Destination 528 (transaction dispatch) from data creation 
5 528, from data usage 502, and from transaction 
fulfillment. 

The JTC interface of the present invention provides 

automatic non-intrusive tracing of application, and 
automatic non-intrusive event logging of application. 
10 The ValidationRules provide class separation of 

chained field validation logic from both GUI and data 
model. Also the ValidationRules can run on client, 
server, or both. 

The Destinations provide plugable data model, 
15 network protocol, and message format modules for remote 
or local fulfillment. Further, Destinations can support 
both local and remote configurations in addition to 
multiple chains of them being called FIFO. The simpler 
the Destinations, the thinner the application. The more 
20 complex the Destinations, the thicker the application. 
The ApplicationMediators can be 
nested- PlacementListeners provide for partitioning of how 
to place components on the screen from what the 
components are and what order they arrive, RequestEvents 
25 (lite transactions) can be broadcast to multiple servers 
using multiple network protocols with various data and 
message formats. 

The architecture also provides permission keys to 
support intra and inter ViewController and 
30 ApplicationMediator user ID and/or group enabling and 
disabling, and provides settable generic field level, 
focus level, and RequestEvent level ValidationRule 
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invocation . 

The ViewControllerBaselmpl provides a mechanism to 
switch between various graphics containers. The example 
code described herein is illustrated in Java, but the 
5 processes of the present invention may be applied to 
other programming languages. 

IV. Class Hierarchy 

With reference now to Figure 6, a diagram 

10 illustrating classes in a class hierarchy is depicted in 
accordance with a preferred embodiment of the present 
invention. Class hierarchy diagram 600 illustrates the 
class hierarchy of new classes introduced by the present 
invention. All of the classes are inherit from the class 

15 j ava . lang.Obj ect . These classes provide an architectural 
pattern for client development in Java. The classes 
illustrated in class hierarchy diagram 600 contain 
interfaces and classes to support the architectural 
pattern of the present invention. Although the depicted 

20 examples are illustrated with respect to Java, the 

architectural pattern of the present invention may be 
applied to other types of programming environments. The 
depicted examples are not meant to be limitations on the 
programming environment in which the present invention 

25 may be applied. 

With reference now to Figure 7 , a unified modeling 
language diagram is depicted in accordance with a 
preferred embodiment of the present invention. Unified 
modeling language (UML) diagram 700 is a diagram 

30 illustrating the class hierarchy between various classes 
and interfaces within the architectural pattern of the 
present invention. 
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UML diagram 700 uses the following conventions. A 
sub-interface of another interface {e.g., ViewController 
702 to JTC 742) or a subclass of another class (e.g., 
ViewControllerlmpl 704 to ViewControllerBaselmpl 706) is 

5 shown by a solid line from the subclass to the parent 
class where there is an open arrowhead. If a class is 
used to implement an interface, then a dashed line goes 
from the class to the arrowhead at the interface (e.g., 
ApplicationMediatorlmpl 720 to ApplicationMediator 718) . 

10 A class or interface may be aggregated into another; this 
is indicated by a solid line connecting to a small 
diamond (e.g., ViewEvent 714 to ViewListener 718). The 
end with the small diamond represents the class that is 
aggregating (or containing) the class at the other end. 

15 The multiplicity of the association is indicated by 

numbers at each end of the line, such as ViewEvent having 
multiplicity of 0 to many (with ''many" indicated by 
and ViewListener 718 having multiplicity one. So each 
instance of a ViewListener 718 may contain zero or more 

20 instances of ViewEvent 714. 

Occasionally, alternative methods may be present for 
implementing an object. For example, 

ViewControllerBaselmpl 706 may implement a Container by 
either using the Java Abstract Window Toolkit (AWT) Panel 
25 707 or a JFC 709. The small dashed lines indicate a 
choice. 

Turning now to a discussion of the classes 
illustrated in Figures 6 and 7, ViewController 702 is an 
interface that defines an interface for a class that will 
30 be a single Component containing user interface 

components that are logically related to show information 
to the user and take input from the user. In particular, 
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ViewController 702 is a public interface that defines 
reusable graphics components as part of an overall client 
application. 

With reference now to Figures 8A and 8B, diagrams 
5 illustrating variables and methods in ViewController 702 
are depicted in accordance with a preferred embodiment of 
the present invention. The abstract ViewControllerlmpl 
class implements the ViewController interface to provide 
default behavior where possible. The user can subclass 
10 ViewControllerlmpl so that not all of the interface 
methods of ViewController need be implemented. 

The ViewControllerlmpl 704 is an abstract class 
implementation of ViewController. ViewControllerlmpl 704 
and ViewController 702 are the basic GUI building blocks 
15 for thin clients. ViewControllerlmpl 704 provides the 

function that will be required by a subclass (not shown) . 

ViewControllerlmpl 704 is controlled and mediated by an 
ApplicationMediator . ViewControllerlmpl 704 extends the 
ViewControllerBaselmpl class and implements the 
20 ViewController interface so as to support the event 

handling methods and provide a default implementation for 
the other ViewController methods. This class maintains a 
reference to the client data model, the user validation 
level, and the UI properties and resources. Methods are 
25 present to add and remove listeners for view events 

generated, fire (send) view events to the appropriate 
listeners, cleanup list of event listeners on clear and 
exit, and enable or disable the panel. 

With reference now to Figures 9A-9C, diagrams 
30 illustrating variables, constructors, and methods for 

ViewControllerlmpl 704 are depicted in accordance with a 
preferred embodiment of the present invention. Table 900 
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in Figure 9A illustrates the variables used in 
ViewControllerlmpl 704, The tables used to describe the 
class include a name of the variable, constructor, or 
method, a declaration for the variable, and a description 

5 for the variables. Table 902 in Figure 9B contains a 
similar table for the constructor used in 
ViewControllerlmpl 704. ^ Table 904 in Figure 9C provides 
a list of the methods used within ViewControllerlmpl 704. 
Similarly, table 904 includes a name for the method, a 

10 declaration used for the method, and a description of the 
method. 

ViewControllerlmpl 704 is usually a Java Component 
or Container or bean with the extra methods specified 
here. The basic operation of a ViewControllerlmpl is 

15 handles using the following steps: (1) implement the 
ViewController and JTC interfaces; (2) add your bean 
specific methods; (3) create and compose GUI ; (4) return 
the Component in getComponent () ; (5) return and set 
permission keys, resources and properties when asked; (6) 

20 update permission keys, resources and properties when 

asked; (7) handle internal AWT events; (8) validate and 
format fields with ValidationRules ; (9) issue ViewEvents 
for semantic interpretation; (10) return to the AWT 
Thread as soon as possible; (11) handle refresh (data) 

25 calls by updating GUI; (12) access data; and and (13) 
repeat from step (3) . 

ViewControllerlmpl 704 is controlled and mediated by 
an ApplicationMediator . The default function provided by 
this class includes: from ViewController interface: 

30 add/ remove ViewListener, f ireViewEvent, 

setValidationLevel, refresh, getComponent, and AWTEvent 
threading. From the JTC interface, the functions 
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provided include: clear, exit, set/getEnabled, 

set/getVisible, and toString. 

ViewControllers know the full semantics of the data 

model being used, even though only a generic Object data; 
5 type reference is provided. The ViewControllers will cast 

generic reference into Class based data objects. Some 

design principles to use in ViewControllers when deciding 

how to * communicate information to ViewListeners are 

described below. 
10 A ViewEvent is created, its setter methods are 

called, and it is fired to the ViewListeners. The 

listeners interpret the major and minor codes to decided 

what to do. 

To provide additional information, the 
15 ViewController can set a Java data object in the 

ViewEvent using the setData method. The data reference 

can be simple String objects or user defined data 

objects . 

A similar approach to provide additional information 
20 is for the ViewController to supply application defined 
objects using the setData method. The data reference are 
more complex than simple objects (i.e. Customer, 
Accountlnfo, Schematic, CarSpec, etc.). 

The ViewController also can provide named methods. 
25 For example, a ViewListener may call 

customerVC.getCustomerName () to retrieve the customer 
name. The implementation of getCustomerName is hidden by 
the ViewController and could involve manipulating several 
Java Components. In addition, setters may also be 
30 provided, such as VC. setCurrentCustomer ( ) . In general, 
too many named methods may suggest that information 
sharing should be via data objects within ViewEvents and 
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refresh methods instead. The use of named methods may 
reduce reuse of a ViewController by an 
ApplicationMediator . 

The ViewController may listen to property change 
5 events on a data model using standard Java mechanisms. 
Thus, the ViewListeners, the ViewControllers, or any 
other interested object can communicate via the data 
model changes. In general, this is very data-oriented 
object model programming approach and can lead to 
10 object-spaghetti code. Changes in the data model ripple 
throughout the application. 

ViewControllerBaselmpl 706 is an abstract class and 
is a superclass of ViewControllerlmpl 704. This class 
provides the indirection to allow specification of the 
15 Component type of the ViewController via a "has a" and/or 
"is a" relationship. The idea is for the developer to 
replace this class entirely with the developer's own 
implementation. This replacement may be accomplished by 
creating the developer's own implementation of 
20 ViewControllerBaselmpl that implements the methods 
getComponent ( ) , setEnabled (boolean enable), and 
setVisible (boolean visible). ViewControllerBaselmpl 706 
is generally used with either JPanel 707 or a 
java. awt .Panel 707 by changing the inherits statement. 
25 ViewControllerBaselmpl may also be used with any Java or 
user-defined component or container. The variables, 
constructors, and methods for ViewControllerBaselmpl 706 
are found in Figures 10A-10C. The variable for 
ViewControllerBaselmpl 706 is found in table 1000 in 
30 Figure 10A while the constructors are listed in table 

1002 in Figure 10B. The methods are listed in table 1004 
in Figure 10C. 
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ViewControllerAdapter 708 is an abstract class and 
is a helper adapter class that fits between 
ViewControllerlmpl 704 and the developer's subclass. 
Vi ewCont roller Imp 1 704 implements almost all of the 

5 standard Java AWT listeners and provides empty methods. 
This class allows ViewControllers to be implemented 
without having to specify all of the methods of a Java 
AWT listener interface when a subclass being created 
needs only one such method. 

10 ViewControllerAdapter 708 implements the following 

AWT event listeners: AdjustmentListener , 
ComponentListener, FocusListener, ItemListener , 
KeyListener, MouseListener, TextListener . This class 
knows about everything that ViewControllerlmpl knows, and 

15 also knows the default empty implementation of AWT event 
listener methods. The methods on the class allow for 
adding and removing of listeners for view events 
generated, firing (sending) of view events to the 
appropriate listeners, cleaning up the list of event 

20 listeners on clear and exit, and enabling or disabling 
the panel. 

Figures 11A-11C illustrate a variable, a 
constructor, and methods for ViewControllerAdapter 708. 
Table 1100 in Figure 11A illustrates the variable while 
25 table 1102 in Figure 11B illustrates the constructor of 
ViewControllerAdapter 708. Methods for 
ViewControllerAdapter 708 are shown in table 1104 and 
Figure 11C. 

ValidationRule 710 is an abstract class for 
30 class-based value validation rules used to validate and 
format ViewController contents. Validation is normally 
used for single or groups of text fields (user entry) . 
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Examples include range checking, date, social security 
number, or other business specific formats- The 
definition of the validation rules are kept out of the 
data models and ViewControllers to maximize reuse of 
5 validation logic. These types of objects only encode 
which rule to use. 

Typically, validation rules have two methods: (1) 
edit and (2) normalize. The edit method is used to input 
a string, validate the value and output the view friendly 

10 formatted string. The normalized method is used to input 
a string, validate the value and output a string that 
will be set into the data model and/or transmitted via a 
RequestEvent to a destination. For example, given a 
value of "1000.0", edit will produce "$1,000.00" and 

15 normalize will produce "1000". The ValidationRule 710 
provides two static helper functions to apply edits or 
normalizes on an input string given a list of edit rule 
class names. This is called ValidationRule chaining. In 
this manner, ValidationRule 710 allows a developer to 

20 keep the implementations of validation rules small and 
simple so as to maximize reuse of validation code. 
Additionally, ValidationRule 710 may be run on a server. 
The methods can create an instance of a ValidationRule 
given a class name, apply edit rules sequentially on a 

25 string given a list of ValidationRule class names, or 
apply normalize rules sequentially on a string given a 
list of ValidationRule class names. Invocation of a 
validation rule is initiated by the ViewController or 
some business logic method. In case of failure, a 

30 ValidationRuleException is thrown. 

With reference now to Figures 12A-12C, drawings 
illustrating variables, constructors, and methods for 
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ValidationRule 710 are depicted in accordance with a 
preferred embodiment of the present invention. The 
variables are illustrated in table 1200 in Figure 12A 
while the constructor is shown in table 1202 in Figure 
5 12B for ValidationRule 710. The methods used in 

ValidationRule 710 are shown in table 1204 in Figure 12C. 
Figure 12D contains code 1206, which is used to apply 
ValidationRules for classes in response to ValidationRule 
710 being given a list of class names for processing) . 

10 Code 1206 will apply each ValidationRule for a class and 
return a formatted result. A similar code is used for 
ValidationRule . applyNormalizes . 

ValidationRuleException 712 is a class that extends 
the Exception class in Java to represent the type of 

15 exceptions thrown by rules defined in ValidationRule 710. 
ValidationRuleException 712 is generated when a 
validation rule has failed. The cause of the failure is 
contained in the exception. In the depicted examples, 
processing of remaining validation rules will halt. This 

20 class needs to know the validation rule exception string. 

With reference now to Figures 13A and 13B, tables 
illustrating variables and constructors for a 
ValidationRuleException are depicted in accordance with a 
preferred embodiment of the present invention. Table 

25 1300 in Figure 13A illustrates a variable while table 
1302 in Figure 13B illustrates constructors for 
ValidationRuleException 712. 

ViewEvent 714 is a class having a mechanism used for 
communication between ViewControllers and ViewListeners, 

30 such as ApplicationMediators and between 

ApplicationMediators, Notification occurs when a 
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significant AWTEvent has occurred that the ViewController 
cannot handle. Both ViewControllers and 

ApplicationMediators can fire ViewEvents. The ViewEvent 
state includes a major code, a minor code, a source 

5 Object of the event, and a generic Object data reference. 
Numerous predefined major codes and minor codes are 
provided and a subclass can define additional application 
specific codes- 

When a ViewController fires a ViewEvent, it is 

10 handled in the ApplicationMediatorlmpl superclass first 
and then forwarded to the ApplicationMediatorlmpl 
subclass in the processViewEvent method. This mechanism 
allows threading and queuing to be handled by the 
superclass* Dispatching a ViewEvent to a subclass is 

15 performed in one of two ways: queued-event dispatching 
and thread-event dispatching. 

With reference now to Figures 14A-14D, diagrams 
illustrating variables, constructors, and methods for 
ViewEvent 714 are depicted in accordance with a preferred 

20 embodiment of the present invention. Table 1400 in 

Figures 14A-14D illustrates variables for ViewEvent 714. 
Table 1402 in Figure 14E shows the constructors for 
ViewEvent 714. The methods for ViewEvent 714 are shown 
in table 1404 in Figure 14F. 

25 ViewListener 716 is an interface for receiving 

ViewEvents generated by ViewControllers. The listener 
will be called back on the viewEventPerformed method. 
ViewListener 716 interprets the values from the ViewEvent 
and decides what action to take. If more information 

30 needs to be conveyed, ViewListener 716 gets the data 
variable. A ViewListener can set the ViewEvent to be 
consumed. When the ViewEvent is consumed, the ViewEvent 
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will not be forwarded to other ViewListeners. 

Turning now to Figures ISA and 15B, diagrams 
illustrating a variable and a method for ViewListener 716 
are depicted in accordance with a preferred embodiment of 
5 the present invention* The variable for ViewListener 716 
is shown in table 1500 in Figure 15A. The method used in 
ViewListener 716 is shown in table 1502 in Figure 15B. 

ApplicationMediator 718 is an interface that 
specifies methods for the management of 
10 PlacementListeners, ViewListeners, RequestListeners, 
TopListeners, permissions, properties, resources, 
visibility, validity. ApplicationMediator 718 also 
defines a generic method to refresh data. 

ApplicationMediator 718 defines the interface for a class 

15 that will mediate multiple ViewControllers or other 

AppiicationMediators, Methods are provided in this class 
to add and remove PlacementListeners for the 
ViewControllers, to add and remove TopListeners for the 
ApplicationMediator, to add and remove RequestListeners 

20 for RequestEvents generated, and to add and remove 
ViewListeners for ViewEvents passed up from the 
ViewControllers. Other methods in the 
ApplicationMediator 718 set the data used by the 
ViewControllers, tell where and how to handle ViewEvents 

25 generated by ViewControllers, and generate RequestEvents 
based on some application logic of ViewEvents* Methods 
are provided in this interface to set the property 
information and the resources used by the 
ViewControllers . 

30 The Figures 16A and 16B, diagrams illustrating a 

variable and methods for ApplicationMediator 718 are 
depicted in accordance with a preferred embodiment of the 
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present invention. Table 1600 in Figure 16A illustrates 
the variable used for ApplicationMediator 718 while table 
1602 in Figure 16B illustrates the methods used in 
ApplicationMediator 718. 
5 ApplicationMediatorlmpl 720 is an abstract class, 

implements the ApplicationMediator interface, and 
provides default behavior to manage ViewControllers, 
ApplicationMediators, add/ fire/ remove of 
PlacementListeners, RequestListeners, ViewListeners and 

10 TopListeners . A subclass of ApplicationMediatorlmpl 718 
should focus on managing the state machine for ordering 
the ViewControllers it creates and the mediating of 
events. This focus includes determining which 
ViewController to allocate, which ViewController to make 

15 visible, when to fire a PlacementEvent, when to fire a 

RequestEvent, and when to fire a TopEvent. A default list 
is provided to hold ViewControllers. The default list is 
a Vector and is directly available to subclasses. An 
ApplicationMediatorlmpl 720 may create other 

20 ApplicationMediators . As a result, a list to hold 
ApplicationMediators also is provided. 

The helper methods initApplicationMediators and 
initViewControllers will load their respective classes 
and store them in Vectors. The helper methods getAM, 

25 getVC, setAM, and setVC provide a way to get /set the 
elements in the Vectors. 

When a ViewController fires a ViewEvent, the 
ViewEvent is handled in ApplicationMediatorlmpl 720 first 
and then forwarded to the subclass (not shown) in the 

30 processViewEvent method. This process allows threading 
and queuing to be handled first by 
ApplicationMediatorlmpl 720. 
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ApplicationMediatorlmpl 720 needs to have reference 
to the client data model, PlacementListeners, 
TopListeners, ViewListeners, ViewControllers, other 
ApplicationMediators, UI properties and resources, and 
5 Event processing threads. 

Methods are provided in ApplicationMediatorlmpl 720 
to add and remove listeners for ViewEvents generated or 
forwarded from a ViewController, to fire (send) 
ViewEvents to the appropriate listeners, to add and 
10 remove listeners for RequestEvents generated, and to fire 
TopEvents and to fire (send) synchronous or asynchronous 
RequestEvents to the appropriate listeners. Other 
methods add and remove listeners for PlacementEvents 
generated, fire (send) PlacementEvents to the appropriate 
J; 15 listeners, and cleanup a list of event listeners and 

event processing threads on clear and exit. It is also 
: JS possible to enable or disable the visibility, create, 

; !f initialize, and manage ViewControllers, and to create, 

s initialize, and manage other ApplicationMediators. Other 

\Z 20 methods get references of all JTC objects managed, set 

llj client data references for all ViewControllers and 

! ^ ApplicationMediators managed, add TopListeners, and 

yg handle the processing of a received ViewEvent in a 

separate thread (either in a queue fashion or unique 
25 thread per event) . 

Turning next to Figure 17A-17D, diagrams 
illustrating variables and a constructor for 
ApplicationMediatorlmpl 720 are depicted in accordance 
with a preferred embodiment of the present invention. 
30 Table 1700 in Figure 17A illustrates variables for 

ApplicationMediatorlmpl 720 while table 1702 in Figure 
17B shows the constructor used in ApplicationMediatorlmpl 
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720. Table 1704 in Figures 17C and 17D illustrate the 
methods used in ApplicationMediatorlmpl 720. 

With reference now to Figures 17E-17H, diagrams 
illustrating code used in methods for 

5 ApplicationMediatorlmpl 720 are depicted in accordance 

with a preferred embodiment of the present invention. In 
Figure t 17E, code 1706 illustrates code used in an exit 
method for ApplicationMediatorlmpl 720. This code allows 
the ApplicationMediator to be exited by exiting all 

10 allocated ViewControllers and ApplicationMediators . All 
data will be set to null by code 1706 and all lists 
destroyed. 

In Figure 17F, code 1708 illustrates code used to 
clear an ApplicationMediator by clearing all allocated 
15 ViewControllers and ApplicationMediators. The data is 
set to null, but the lists are not destroyed. A cleared 
ApplicationMediator can be used again. In Figure 17G, 
code 1710 is used to initialize an ApplicationMediator 
using the listeners of an existing ApplicationMediator. 
20 In Figure 17H, code 1712 is used to refresh an object. 
This code is used to refresh ViewControllers and 
ApplicationMediators when new data arrives. In Figures 
17I-17L, depicts code 1714 which is used to handle the 
event dispatch. 
25 PlacementEvent 722 is a class used to notify 

PlacementListeners that a ViewController needs to be 
adjusted on the screen. The value stored in a 
PlacementEvent 722 are: (1) major code indicating the 
placement type; (2) minor containing additional 
30 information; (3) source, which indicates the sender of - 
the event; (4) Component, which is the ViewController' s 
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component; and (5) data, which is a generic Object data, 
containing the type to pass more information and is 
typically not the same type of data sent in ViewEvents 
and RequestEvents. Predefined placement types, which are 
5 used as major codes include, for example, add, remove, 
and modify. A subclass may define more application 
specific PlacementEvent codes. Additional information 
may be* conveyed through the use of the minor variable or 
by supplying real data. 

10 With reference now to Figures 18A-18C, diagrams 

illustrating variables, constructors, and methods for a 
PlacementEvent are depicted in accordance with a 
preferred embodiment of the present invention. Table 
1800 in Figure 18A illustrates variables used within 

15 PlacementEvent 722 while table 1802 in Figure 18B show 
constructors used for PlacementEvent 722. Table 1804 in 
Figure 18C shows the methods used within PlacementEvent 
722. 

PlacementListener 724 is an interface used to manage 
20 the placement of ViewControllers on the screen. For a 
given component or container, such as a ViewController, 
PlacementListener 724 controls the placement while 
ApplicationMediator controls the ordering of 
ViewControllers instead of their placement. For example, 
25 if a designer wishes to create a split pane with a tree 
in the left pane that allows selection of 

ApplicationMediators, ViewControllers will display on the 
right. As a result, an "add" method is called to the 
split pane. If a frame is used, "add" has a different 
30 syntax. An object handling placement of components will 
register as a listener for notifications to place objects 
on the screen. This role is the one played by 
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PlacementListener 724. The ApplicationMediator controls 
the ordering of ViewControllers, not their placement. A 
PlacementListener adds itself to a PlacementEvent 
generator and is called back with a PlacementEvent which 
indicates a desired action. This mechanism allows 
complete separation between view creation 
(ViewController) , view ordering (ApplicationMediator), 
and view placement (PlacementListener) . This arrangement 
increases the reusability of ViewControllers and 
ApplicationMediators to nearly 100% with respect to 
placement . 

With reference now to Figures 19A and 19B, diagrams 
illustrating a variable and method for a 
PlacementListener are depicted in accordance with a 
preferred embodiment of the present invention. Table 
1900 in Figure 19A illustrates the variable used in 
PlacementListener 724 while table 1902 in Figure 19B 
illustrates the method used in PlacementListener 724. 

TopEvent 726 is a class used to notify TopListeners 
that ApplicationMediator needs some desktop function to 
occur. The value stored in TopEvent include: (1) major, 
which identifies the TopEvent type; (2) minor, which 
contains additional information; (3) source, which 
identifies the sender of the Event; (4) consume, which 
will result in the Event being processed if true; and (5) 
data, which is a generic object data used to pass more 
information. Predefined types, which are used as major 
codes include, for example, EXEC, BROWSER, , TITLE, 
STATUS, and OS. This category of types is used for 
interaction with the desktop (operating system, browser, 
other applications) . Additional major codes include 
TRANSPORTER, DESTINATION, APPLICATION MEDIATOR, , 
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REQUEST EVENT, VIEW_CONTROLLER, VIEW_EVENT, TOP_LISTENER, 
TOP EVENT, PLACEMENT_LISTENER, PLACEMENT__EVENT , MAJOR, 
MINOR, AWT_EVENT, and JTC. This category of types is 
used to indicate a reconfiguration of the JTC 
5 application. Additional TopEvent codes may be defined 
through the use of subclasses. Additional information 
may be conveyed by using the minor variable or supplying 
real data. 

With reference now to Figures 20A-20C, diagrams 

10 illustrating variables, constructors, and methods for a 
TopEvent are depicted in accordance with a preferred 
embodiment of the present invention. 

Table 2000 in Figure 20A illustrates the variables 
contained in <update this tabled based on latest javadoc 

15 contents> TopEvent 726 while table 2002 in Figure 20B 

shows the constructors for TopEvent 726. The methods for 
TopEvent 726 are found in table 2004 in Figure 20C. 

TopListener 728 is an interface that performs 
business specific desktop duties for a display. 

20 TopListener 728 provides an interface that is highly 
customizable for each business application. This 
interface specifies a topEventPerf ormed method to receive 
a TopEvent encoding a task to be performed. 

With reference now to Figure 21A and 21B, diagrams 

25 illustrating a variable and methods for TopListeners are 
depicted in accordance with a preferred embodiment of the 
present invention. Table 2100 in Figure 21A illustrates 
the variable for TopListener 728 while table 2102 in 
Figure 21B illustrates the methods in TopListener 728. 

30 The RequestEvent 730 is a class that extends 

EventObject to represent RequestEvents generated by 
ApplicationMediators. This class represents a 
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lite-weight transaction. The instances of this class 
denotes a unit of work, RequestEvent 730 represents a 
request for a transaction or data from a source external 
to the application. The request is handled by a remote 
5 or local destination. The Transporter is responsible for 
mapping RequestEvents to Destinations. The state of a 
RequestEvent 730 includes the following information: (1) 
major code identifying a family of RequestsEvents ; (2) 
minor code identifying a specific request under the 
10 family) ; (3) version, which is usually user defined; (4) 
status which may be an appended string showing the stages 
of processing; (5) consume (a consumed Request Event will 
cause JTC to stop processing the Request Event); and (6) 
Q data, which may be, for example a reference to generic 

'% 15 Object data. A RequestEvent can be set to be consumed in 

ty which case Destinations and the Transporter will halt 

forwarding of the RequestEvent and return control to the 
FU ApplicationMediator . 

Turning now to Figures 22A-22C, diagrams 
M 1 20 illustrating a variable, constructors, and methods for 

I^i RequestEvent are depicted in accordance with a preferred 

: ll embodiment of the present invention. Table 2200 in 

yS Figure 22A illustrates the variable in RequestEvent 730. 

Table 2202 in Figure 22B shows the constructors used in 
25 RequestEvent 730. Table 2204 in Figure 22C illustrates 
the methods in RequestEvent 730. 

RequestException 732 is a class that extends 
Exception to represent the type of exception thrown when 
there is a problem in submitting a RequestEvent. This 
30 class is used when the processing of a RequestEvent 

causes an error condition. This exception can be thrown 
directly when a synchronous or asynchronous RequestEvent 
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is performed. This indicates failure in synchronous 
processing or failure in the fire mechanism. The 
exception can be thrown indirectly when asynchronous 
RequestEvent is processed. The cause of the failure is 
5 also indicated in the exception in the depicted examples. 
Thus, this class needs to know the string representing 
the reason for the RequestEvent exception. 

With reference now to Figures 23A-23C, diagrams 

•XT 

illustrating a variable, constructors, and methods for 
10 RequestException 732 are depicted in accordance with a 
preferred embodiment of the present invention. Table 
2300 illustrates the variable for RequestException 730 
while table 2302 in Figure 23B illustrates the 
J constructors used in RequestException 732. The methods 

•** 15 for RequestException 730 are found in table 2304. 

h* The RequestListener 734 is an interface that defines 

:]y the method for a class to implement for receiving 

ifl synchronous or asynchronous RequestEvents . This 

^ interface is implemented by classes that want to listen 

Q 20 and be notified when a RequestEvent is fired. A typical 
;| example is a Transporter instance. The RequestListener 

■M is added to an ApplicationMediator as a listener for 

RequestEvents. Two styles of notification are possible: 
synchronous and asynchronous. The Transporter implements 
25 the RequestListener interface to map RequestEvents to 
Destinations. Other classes can implement the 
RequestListener interface and register for RequestEvents 
to monitor them. A RequestException can be thrown 
directly when invoking synchronous and asynchronous 
30 RequestEvents or on a callback when invoking only 
asynchronous RequestEvents. 

With reference now to Figures 24A and 24B, diagrams 
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illustrating a variable and methods for a RequestListener 

are depicted in accordance with a preferred embodiment of 

the present invention. Table 2400 in Figure 24A 

illustrates the variable in RequestListener 734 while 

5 table 2402 in Figure 24B illustrates the methods used in 

RequestListener 734. 

RequestResponseListener 736 interface is implemented 

» 

by a class that requires asynchronous RequestEvent 
processing. For example, when an ApplicationMediator 

10 implements this interface, it will be called back on one 
of the two methods after it fires asynchronous 
RequestEvents . Successful RequestEvents are returned 
through the requestResponse method and passed a 
RequestEvent that may have new data. Unsuccessful 

15 RequestEvents are returned through the requestException 
method and the RequestException contains the reason. 

Turning now to Figures 25A and 25B, diagrams 
illustrating a variable and methods for a 

RequestResponseListener are depicted in accordance with a 
20 preferred embodiment of the present invention. Table 
2500 in Figure 25A shows the variable in 
RequestResponseListener 734 while table 2502 in Figure 
25B illustrates the methods in RequestResponseListener 
736. 

25 The Transporter 730 is a class that implements the 

JTC and RequestListener interfaces. The primary function 
of Transporter class 730 is to map RequestEvents to 
Destinations. In other words, Transporter 738 acts as an 
event broadcaster to route RequestEvents to the 

30 appropriate Destination. Typically, ApplicationMediators 
fire RequestEvents which are routed to a Destination by 
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the Transporter. The Destination processes the 
RequestEvent by performing some interpretation and 
sending them to a target, such as a server. This event 
broadcasting is performed by Transporter 738 based on the 
5 major code of the RequestEvent in the depicted examples. 
Transporter 736 needs to know the Destinations, the major 
codes registered by the Destinations, RequestEvents, 
RequestResponseListener, and RequestExceptions . 

Methods are provided in Transporter 738 to register 

10 a Destination that processes RequestEvents with a 
specific major code, remove the registration of a 
Destination, receive a RequestEvent for synchronous or 
asynchronous processing, handle the processing of a 
received asynchronous RequestEvent in a separate thread 

15 (either in a queue fashion or unique thread per event) , 
and return a list of Destinations registered for a 
specific key (major code) . Other methods cancel the 
processing of an asynchronous RequestEvent, cleanup 
threads and lists of Destinations on clear and exit, 

20 enable or disable the sending of RequestEvents to 

Destinations f and enable or disable the tagging (status 
setting) of RequestEvents. 

With reference now to Figures 26A-26C, diagrams 
illustrating variables, a constructor, and methods for a 

25 transporter are depicted in accordance with a preferred 
embodiment of the present invention. Table 2600 in 
Figure 26A illustrates variables for Transporter 736 
while table 2602 in Figure 26B illustrates a constructor 
for Transporter 738. The methods for Transporter 738 are 

30 illustrated in table 2604 in Figure 26C. 

Turning now to Figures 26D-26E, diagrams 
illustrating code used in methods in Transporter 738 are 
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depicted in accordance with a preferred embodiment of the 
present invention. Code 2604 in Figure 26D illustrates 
processing or selecting Destinations in response to a 
RequestEvent . Given a RequestEvent of Destinations, code 
5 2604 will call each Destination in a first in first out 
(FIFO) / first exception first return (FEFR) order. Code 
2606 in Figure 26E illustrates a process for submitting a 
synchronous request. For each Destination listening for 
the current family of RequestEvents, as indicated by the 
10 major code, the RequestEvent is sent to a Destination for 
processing. If a problem occurs, a RequestException is 
thrown. Processing the RequestEvent will occur as long 
as a RequestException being thrown is not from a 
S Destination and the RequestEvent is not consumed. 

15 Submission of an asynchronous request is performed by 
code 2608 in Figure 26F. Code 2610 in Figure 26G 
illustrates code for handling executions of submits on 
another thread. 

The Destination 740 is an interface used to pass 
20 results or events. This interface is implemented by 
classes that want to listen to Transporters and send 
RequestEvents to servers. Destination 740 performs the 
following functions: (1) server: locate it; (2) network 
transports: create the low level protocols such as 
25 sockets, RMI, URLs, Files, etc.; (3) server types: be 
able to talk to different servers such as EJBs, 
Servlets, web servers, legacy, etc.; (4) message formats: 
be able to turn RequestEvents and data into formats that 
the servers understand; (5) timeouts: finish the job in 
30 the appropriate amount of time or cancel the operation; 
(6) retries: how many times should a connection be 
tried; (7) caching: save data until it becomes stale; 
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(8) stale data: detect stale data; (9) heart beats: I 

am alive; (10) logging: save pre and post RequestEvents; 

and (11) objects: locate them, create them. 

Example Destinations behaviors include the 

5 following: (1) serializing a request and writing it to a 

socket, (2) reading and writing requests and responses 

from a file for demonstrations, (3) casting the data in a 

> 

RequestEvent into objects and so that RMI methods are 
visible, (4) debugging, (5) tracing, (6) compression, (7) 

10 encryption, and (8) translation. 

A Destination 740 is first added to a Transporter as 
a RequestListener, listening for RequestEvents of a 
specific major code. When RequestEvents enter the 
Transporter, these RequestEvents are sent to each 

15 listening Destination via a requestEventPerf ormed. 

Additionally, a Destination monitors the state of the 
consumed attribute of the RequestEvent and will terminate 
processing when the state is true. 

RequestEvents are identified by a major code 

20 (represents a family of Requests) and a minor code 

(represents a specific Request) . Destinations are added 
to the Transporter as DestinationListeners specifying a 
major code for RequestEvents they are interested in 
receiving. The Destination is called when the major code 

25 of the RequestEvent matches the Destination's major code. 
Multiple Destinations can listen for the same 
RequestEvent major code and results of one Destination 
can be passed to the next Destination. RequestEvents are 
processed in a first in first out (FIFO) / first 

30 exception first return (FEFR) order. 

With reference now to Figures 27A and 27B are 
diagrams illustrating a variable and methods for a 
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Destination in accordance with a preferred embodiment of 
the present invention. Table 2700 in Figure 27A 
illustrates the variable in Destination 740 while table 
2702 in Figure 27B illustrates the methods used in 

5 Destination 740. 

Destinationlmpl 742 is an abstract class that 
implements the Destinatipn interface and provides a 
default implementation for the Destination interface 
methods. It needs to know whether the Destination is 

10 enabled or disabled, whether the RequestEvents are tagged 
with a status or not, and the RequestEvent processing 
timeout value. Methods are provided to enable or disable 
the processing of RequestEvents in the Destination and to 
set the RequestEvent processing timeout value. 

15 With reference now to Figures 28A-28C, diagrams 

illustrating variables, constructors, and methods for a 
Destinationlmpl are depicted in accordance with a 
preferred embodiment of the present invention. Table 
2800 in Figure 28A illustrates the variable used in 

20 Destinationlmpl 742 while table 2802 in Figure 28B 

illustrates the constructor used in Destinationlmpl 742. 
Methods for Destinationlmpl 742 are illustrated in table 
2804 in Figure 28C. 

In Figure 28D, code 2806 is used to process a 

25 RequestEvent. If an application uses a set of objects 

that perform the retrieval and update of data, then those 
objects can be accessed from a generic Destination class. 
Typically, a Destination implementation accesses a single 
interface class with methods and is written specifically 

30 to serve one purpose (i.e. the retrieval and update of 
customer data or the retrieval and update of employee 
data) . However, a generic Destination class can be 
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written to retrieve and update any set of data. The 
requirement is that the class/object that serves the data 
must all have methods with the same interface (in other 
words, they must take in the same number and type of 
object as parameters and return the same type or generic 
object.) This way, the Destination class can be 
implemented to use Java's reflection to access/create the 
object 1 and invoke a particular method on the object. The 
major code of the RequestEvent can specify the class name 
and the minor code can specify the method name. The code 
in Figure 28D shows how a Destination can be implemented 
to access an Enterprise JavaBean session bean instance 
from an application server using Java T s RMI and Java's 
Reflection capabilities. The methods on the session 
beans all take a single parameter of type Object and 
return a parameter of type Object. The client user 
interface and the session beans know the specific type of 
data objects passed but the Destinations do not need to 
know about the data. 

JTC 744 is an interface that provides a top level 
interface in the architecture of the present invention. 
All major objects in a JTC application implement this 
interface including the driver programs that launch the 
application/applet . This interface provides the ability 
to reference all objects using a single type. The 
behaviors expected include clear, exit, getJTCs, init, 
isEnabled, setEnabled, and toString. The interfaces 
that extending JTC are ViewController, 
ApplicationMediator, and Destination. The classes 
implementing JTC are ViewControllerlmpl, 
ApplicationMediator Impl, Transporter, and 
Destinationlmpl . 
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Of particular importance is the getJTCsO method. 
Each JTC object returns the other JTC objects it creates. 
Iteration over these objects is possible. Inspection of 
the object types and addition of the appropriate 
5 listeners may be performed. This interface provides a 
mechanism for non- intrusive logging, tracing and 
debugging . 

Factory 746 is a class used to make objects. This 
class is the place for code relating to prefetching, 

10 caching, and alternative "styles" for the new operator 
(or construction of objects), or loading a serialized 
object. The alternative "style" may be, for example, 
using Class . forName . The default behavior of a Factory 
includes, for example, creating a single object. 

15 Additionally, the behavior may include returning a 
previously created object if a key has been used or 
otherwise creating a new object and remembering the 
object . 

Further, Factory 746 may be used to create multiple 
20 objects. Also, if a key[i] has been used, a previously 
created object may be returned. Otherwise, a new object 
[i] may be created and remembered by the Factory. For 
example, on a single JVM, a designer may want to create a 
single shared instance of a Transporter. Each access to 
25 the Transporter should be as follows: Transporter t = 
Factory. newlnstance (com. ibm.jtc. Transporter, true) . In 
this case, the Class . forName method is used with the key 
to create an instance of the Transporter. The true value 
indicates that a singleton may be created. The singleton 
30 may be turned off in which case all objects created are 
new and not remembered. Another key also may be used 
besides the class name. An example is as follows: 
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Customer c = Factory .newlnstance ( n CUST", 
com. abc. Customer, true). The user can create a single 
object or create multiple of objects. For example, on a 
single JVM, a user may want to create and share one 
5 instance of a Transporter. The Factory class needs to 
know the list of singleton classes managed. The methods 
in this class provide several ways to create an instance 
of a class given one or more full path class name 
strings. The Factory class also can remove stored 
10 references of singleton classes. 

With reference now to Figures 29A and 29B, diagrams 
illustrating variables and methods in a Factory are 
depicted in accordance with a preferred embodiment of the 
present invention. Table 2900 in Figure 29A illustrates 
15 the variable used in Factory 746 while table 2902 in 
Figure 29B illustrates the methods for Factory 744 . 

Q 740 is a class representing a queue of objects 
that are added and removed in first-in first-out (FIFO) 
ordering. The size of the queue can be set to a maximum 
20 or as unbounded. The structure maintains the queue of 
objects, the current size of queue, and the front and 
back ends of the queue. Methods are provided to add an 
object to the back end of the queue, remove an object 
from the front of the queue, and predicates to check if 
25 the queue is empty or full. 

JTC 744 is a top level interface, which all major 
objects in an application created using the architecture 
of the present invention should implement. This would 
include driver programs that launch the application. 
30 This interface allows referencing of objects with a 
consistent type and a similar expected behavior. 

Of particular importance in this class is the 
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getJTCsO method. Each JTC object returns the other JTC 
objects it creates. With this interface, a process can 
iterate over these objects, inspect their types, and add 
the appropriate listeners. The system may be reconfigured 
5 through this interface. This reconfiguration includes, 
for example, disabling the Transporter, adding a priority 
Destination, and consuming an event. This interface 
provides an excellent mechanism for non-intrusive 
logging, tracing and debugging. For example, if a program 
10 Testl.java implements JTC, it will return the 

Transporter, ApplicationMediators and Destinations it 
creates . 

With reference now to Figure 30A and 30B, tables 
illustrating variables and methods in a JTC is depicted 
15 in accordance with a preferred embodiment of the present 
invention. Table 3000 in Figure 30A illustrates 
variables in JTC while table 3002 in Figure 30B 
illustrates methods for JTC. 

20 V. Steps In Building An Application Using The JTC 
Architecture 

A thin client application or a thick client 
application that follows the JTC architecture of the 
present invention can be built using a top-down, 
25 bottoms-up, or from the middle approach. All approaches 
allow for concurrent development within the JTC client 
application. All approaches all for concurrent 
development of the JTC client application and the server 
and services. 

30 The following steps show a bottoms-up process. A 

proper design of interfaces and subsystem models, will 
ensure that the JTC application can be implemented in 
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parallel . 

A. Design Client Application Subsystems 

The key to the successful implementation of a JTC 

5 application that has reusable and maintainable parts is 
the proper division of the application into logical 
subsystems- This division should be driven by the 
analysis of the application's domain. For example, using 
an object-oriented analysis of the application's domain, 

10 sets of use cases can be developed in the following 
manner. The actors external to the system are 
identified. For example, in designing an automated 
teller machine (ATM) the customer using the machine would 
be an actor and the bank's central computer is also an 

15 actor. The use case is a set of interactions the actor 
or actors have with the system. All sequences of 
interactions, including normal and exceptional behavior, 
should be specified. For example, normal behavior for 
withdrawing cash from an ATM would include a sequence of 

20 prompts and customer responses that eventually lead to 
the dispensing of cash. Exceptions would include an 
unreadable card, an incorrect PIN, insufficient cash in 
the machine, insufficient funds in the account, etc. Use 
cases can include a set of preconditions and 

25 post-conditions. A precondition for the ATM would be 
possession of an ATM card and a post condition, if the 
cash withdrawal is successful, would be an appropriate 
debit from the account balance. 

The use cases produce natural divisions of function 

30 in an application. Use cases describe functions of the 
application that are most likely to be reused within and 
outside of the application. Each use case or possibly a 
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group of fine-grained related use cases should make up 
the logical subsystem model. Groups of ViewControllers 
and ApplicationMediators are implemented in these 
subsystems- A ViewController is used to represent a 
single reusable screen or grouping of information to be 
inputted and/or displayed. An ApplicationMediator 
mediates multiple ViewControllers for a single 
application function or use case. 

Other subsystems of the client application include a 
communications subsystem, a client startup subsystem, 
reusable graphical components, business validation 
rules, and enterprise policies. 

The business logic and central data management of an 
application should be separated out from the JTC 
application. This business logic and data can be 
physically located on any machine. JTC clients typically 
do not keep or manage transaction states; server side 
business logic manages the transaction states. 
Therefore, the coitimuni cat ions subsystem is responsible 
for the sending of data requests and transaction requests 
to the business logic outside of the application. This 
consists of the implementation of RequestEvents and 
Destinations . 

A client startup subsystem manages the client 
application lifecycle and overall look and feel. This 
subsystem includes implementations of TopListeners and 
PlacementListeners . 

Common reusable graphical components used by user 
interface panels should be separated out in their own 
subsystem so that they are designed and implemented for 
reuse and available to other subsystems and applications. 

The rules for validating user input for display 
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format and persistent storage should be separated into 
another subsystem. This allows for central 
maintainability of the rules and reuse across all other 
subsystems and applications. ValidationRules are 
5 implemented in this subsystem. 

Enterprise policies include functions related to 
security, login/ logout, users /groups/roles, profiles, 
locale/ and languages. These requirements cross 
subsystems in a consistent and easily managed manner 

10 through methods including set/getProperties, 

set/getResources, set/getPermissions . Additional non 
functional enterprise polices such as caching, data 
pre-fetching and mobile users are implemented in common 
easily configurable Destination subsystems. 

15 In a bottoms-up approach, the client data model 

should be developed next for the specific subsystem. 
This model specifies the structure and contents of data 
used by the client application. There are a variety of 
approaches to a client data model: Local Object Model, 

20 Workflow Object Model, XML, Named Methods, Key/Value 
Pairs, Ordinal Positioning, RMI, etc. To optimized 
concurrent development with the server and services, a 
bootstrap Key/Value data model is a sufficient and 
expeditious choice. 

25 Once a data model approach is chosen, then the data 

objects must be created. These can be grouped and 
organized at different levels of granularity. In 
general, each component, such as, for example, a 
ViewController or an ApplicationMediator, should only 

30 reference the data the component uses or manages. For 
example, a ViewController should only have data required 
to be displayed on a single screen and the data input by 
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the user on that screen, 

B. Create a ViewController 

In these examples, a ViewController is a panel that 
contains one reusable screen of user display and input. 

5 This screen can either contain Java Abstract Windowing 
Toolkit (AWT) components or Java Foundation Classes 
(JFC/SWing) components- 'The way to choose between the 
two types of components is to implement the 
ViewControllerBaselmpl class. The ViewControllerBaselmpl 

10 class can extend AWT's Panel class or JFC's JPanel class. 
Also ViewControllerBaselmpl can just contain a 
component, container or bean and return it in the 
getComponent ( ) method. In a graphical user interface, 
components are organized into manageable groups through 

15 the use of containers. Additionally, a container may 
provide basic window and dialogue services. A 
java.awt .Panel itself is a pure container. A 
java.awt .Panel itself is not a window in itself, but its 
sole purpose is to organize components in a window. With 

20 reference now to Figure 31, a flowchart of a process for 
creating a ViewController is depicted in accordance with 
a preferred embodiment of the present invention. A 
particular screen is selected to implement (step 3100) 
and a class is created that extends one of the 

25 ViewController implementation classes (step 3102) . This 
class should have a suffix of VC to distinguish it as a 
ViewController class. The init() method is overridden 
(step 3104) and replaced with code to create, initialize, 
and layout graphical components of the panel. Visual 

30 builders (such as IBM VisualAge) can be used to create - 
this method automatically. The refresh () method is 
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overridden (step 3106) . In this method, data to be 
displayed will be passed in. ViewControllers should be 
implemented to be reusable with different sets of data. 
By invoking refresh (), ApplicationMediators can control 
5 for what purpose the ViewController is used. The clear () 
method is overridden (step 3108) . In this method, the 
set of data used is cleared from use and display. This 
allows for the ViewController to be used with another set 
of data. 

10 As part of component initialization, the 

ViewController is added as its component's event 
listeners (step 3110) . The event listeners are 
implemented for the components (step 3112) . 
n ValidationRules are used to validate user input from a 

ssks- 

^ 15 component event (step 3114) . Use ViewEvents (described 

below) to send user inputted data or requests for more 
f! data from an ApplicationMediator . The f ireViewEvent 

|| method and the ViewEvent listeners are used to process 

5 the event (step 3116) . If another ViewController needs 

3 20 to be displayed, use a ViewEvent to represent that 
S request and have the ApplicationMediator process that 

Q request. 

VIII. Create ValidationRule (s) 

Turning now to Figure 32, a flowchart of a process 
25 for creating ValidationRules is depicted in accordance 

with a preferred embodiment of the present invention, A 
ValidationRule implements two methods: edit and 
normalize. A particular business validation rule is 
selected (step 3200) and a class that extends 
30 ValidationRule is created (step 3202) . This class should 
have a suffix of Rule to distinguish it as a 
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ValidationRule class. The edit() method is overridden 
(step 3204). The edit() method takes a user-inputted 
string and generates a formatted output for display. The 
normalize () method takes a user-inputted or formatted 
5 string and generates a normalized output for transmitting 
to some persistent storage (step 3206) . If the normalize 
and edit methods have the same implementation, then 
implement in the edit() method and have the normalize () 
method call the edit() method. The ValidationRule will 
10 compare user input against the selected business rule 
(step 3208) . If the user input is not valid, then a 
ValidationRuleException is thrown (step 3210) and the 
process terminates thereafter. If the user input is 
valid, the process also terminates. 

15 C. Create a ViewEvent 

With reference now to Figure 33, a flowchart of a 
process for creating a ViewEvent is depicted in 
accordance with a preferred embodiment of the present 
invention. In response to AWTEvents, ViewControllers 

20 visually manipulate components, containers and beans. A 
ViewEvent is created for an AWTEvent from a 
ViewController that needs' action to be taken beyond the 
normal visual manipulation capabilities of the 
ViewController. ViewEvents are created by 

25 ViewControllers and processed by ApplicationMediators 

which are ViewListeners . Other ViewListeners can listen 
for ViewEvents to monitor and debug. The details are in 
two choices: 1) an interface is created to contain all 
the various ViewEvent codes used in the application (step 

30 3300), 2) MyViewEvent is a subclass ViewEvent and 

contains the ViewEvent codes. Create an instance of 
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ViewEvent using one of the above codes (step 3302) . Data 
can also be sent with the event and send the ViewEvent 
using f ireViewEvent method of ViewControllerlmpl (step 
3304) with the process terminating thereafter. 

5 D . Create an ApplicationMediator 

An ApplicationMediator class is typically present 
for every application function or use case of the system 
to be developed. An ApplicationMediator creates one or 
more ViewControllers to complete its function. It may 

10 also create other ApplicationMediators for nested 

functions or use cases. With reference now to Figure 34, 
a flowchart of a process to create an ApplicationMediator 
is depicted in accordance with a preferred embodiment of 
the present invention. A particular function is selected 

15 (step 3400) and create a class that extends 

ApplicationMediatorlmpl (step 3402) . This class should 
have a suffix of AM to distinguish it as an 
ApplicationMediator class. The init() method is 
overridden (step 3404) . The ViewControllers used by this 

20 ApplicationMediator are created (step 3406) . The 

initViewControllers () and initApplicationMediators () 
methods can be used to create instances of the classes 
given a list of class name strings. These init methods 
also add the current ApplicationMediator as the 

25 ViewListener for the newly created instances. The 
processViewEvent ( ) method is overridden (step 3408). 

ViewEvents from all ViewControllers and 
ApplicationMediators created by the current 
ApplicationMediator are processed in this method. This 

30 method is called in a separate thread from the AWTEvent 
thread by the viewEventPerf ormed ( ) method of 
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ApplicationMediatorlmpl, so that user processing can 
continue, RequestEvents are created for any requests for 
data or transaction to be processed by business logic 
outside of the client application (step 3410) . These 

5 requests 1 can be synchronous or asynchronous. For 

asynchronous RequestEvents, the requestResponse ( ) and 
requestException ( ) methods must be overridden. Refresh () 
is invoked on the ViewController or ApplicationMediator 
based on the response of the RequestEvent (step 3412) 

10 with the process terminating thereafter. Other possible 
actions based on ViewEvents include, for example, passing 
control to other ViewControllers or ApplicationMediators . 
Also, the ViewEvent can even be sent to higher level 
listeners using the f ireViewEvent method of 

15 ApplicationMediatorlmpl . 

E , Create a RequestEvent 

RequestEvents contain a major code to determine the 
Destination of the request and a minor code to determine 
the type of request. Turning now to Figure 35, a 

20 flowchart of a process for creating a RequestEvent is 

depicted in accordance with a preferred embodiment of the 
present invention. 

An interface for containing the strings of major and 
minor codes of RequestEvents is created (step 3500) . 

25 Major codes determine the Destination but should be based 
on a grouping of related request types. In this manner, 
the processing of these requests can be changed as a 
group. When processing a ViewEvent in an 
ApplicationMediator, a RequestEvent can be created for 

30 requesting data or a transaction from a business logic - 
subsystem that may be outside of the client application. 
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An instance of RequestEvent is created using the 
appropriate major and minor code (step 3502) . The event 
is sent using f ireRequestEvent method of 
ApplicationMediatorlmpl (step 3504) with the process 
5 terminating thereafter* 

F. Create a Destination 

A* Destination takes a RequestEvent and sends it to 
the appropriate location for processing including 
servers, the hosting client environment, an in memory 

10 algorithm, or local devices. Each major code can be 
mapped to a different Destination. This allows the 
client application to access multiple servers and change 
locations of server processing without requiring code 
changes in the client application. 

15 With reference now to Figure 36, a flowchart of a 

process for creating a Destination is depicted in 
accordance with a preferred embodiment of the present 
invention. A particular Destination for processing 
client requests is selected (step 3600) and a class that 

20 extends Destinationlmpl is created step (3602) . In the 
depicted examples, this class has a suffix of Destination 
to distinguish it as a Destination class. The init() 
method is overridden (step 3604) . Any initialization 
required to connect to a particular Destination can be 

25 implemented in this method. The requestEventPerf ormed ( ) 
method is overridden (step 3606) . A RequestEvent is 
passed to this method. The method should send the 
request to the appropriate Destination and update the 
RequestEvent with the response. Use the setStatus 
30 method of RequestEvent to update the processing status of 
the request. If a timeout value has been set, then 
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implement a timeout mechanism for processing the request. 

The Destination should observe the RequestEvent 
consume variable as an indicator that processing should 
be canceled. Next, the finalize () method is overridden 

5 (step 3610) with the process terminating thereafter. If 
connection to a Destination needs to be cleaned up, that 
functionality should be located in this method. The 
TopListener or any other class that starts the 
application should create Destinations and register them 

10 with the Transporter based on the major codes of the 
RequestEvents the Destination handles. 

G, Create a TopListener 

A TopListener manages the overall application. The 
15 TopListener is the entry point into the hosting client 
desktop environment, which includes the operating sytem, 
a browser, and legacy programs. Typically the class that 
contains the top frame of the application will also 
implement the TopListener interface. This class should 
20 have a suffix of Top to distinguish it as a TopListener 
class . 

With reference now to Figure 37, a flowchart of a 
process for creating a TopListener is depicted in 
accordance with a preferred embodiment of the present 

25 invention. A class is created that contains or is the 
top frame of the application and implements the 
TopListener interface (step 3700). An exit() method is 
created (step 3702) and a launch () method is created 
(step 3704). Next, a message () method is created (step 

30 3706) and a title () method is created (step 3708). A 

TopEvent is created and sent to the TopListener with the 
fireTopEvent method. A major code of TopEvent .EXIT 
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indicates that the ApplicationMediator is finished. A 
major code of TopEvent . LAUNCH indicates that the 
ApplicationMediator needs an operating system program to 
be invoked. A major code of TopEvent .MESSAGE indicates 
5 that the ApplicationMediator needs a desktop specific 
message to be displayed. A major code of TopEvent . TITLE 
indicates that the ApplicationMediator needs a desktop 
specific application title to be displayed. 

H. Create a PlacementListener 

10 A PlacementListener is used to place an actual 

component, container or bean (i.e. 

ViewController . getComponent ( ) ) on a frame or window. 
With reference now to Figure 38, a flowchart of a process 
for creating a PlacementListener is depicted in 

15 accordance with a preferred embodiment of the present 

invention. A single type of placement is selected (step 
3800) and creates a class that implements the 
PlacementListener interface (step 3802) . This class 
should have a suffix of Placement to distinguish it as a 

20 PlacementListener class. 

The placementEventPerformed method is then 
implemented (step 3804) with the process terminating 
thereafter. An ApplicationMediator and a Java Component 
is passed in to the method. The component should be 

25 added to some container managed by the PlacementListener 
class . 

I . Assembling the JTC Program 

The JTC pattern for building most client 
applications is now given. This description is the JTC . 
30 pattern. A Destination W D" object is created and 
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initialized. A Transporter object "T" is created and 
initialized. A major code "MC" is defined. "D" is added 
to "T" as a DestinationListener using major code V. 
A main program "P" that implements the JTC, 
5 PlacementListner and TopListener interfaces is created 
and it creates top level frames. 

An ApplicationMediator "AM" object is created. 

- * 

Transporter "T" is added as a RequestListener . Main 
program "P" is added as a PlacementListener and a 
10 TopListener. ApplicationMediator "AM" is initialized. 
ApplicationMediator "AM" creates and initializes one or 
more ViewControllers "VC" and immediately fires a 
PlacementEvent to start the program visuals. 

This is the Java code for the JTC pattern: 
15 public class MyProgram implements JTC, 

PlacementListener, TopListener { 

public static void main (String [] ) { 

20 MyProgram P = new MyProgram(); 

P . createFrames ( ) ; 

MyDestination D = new MyDestination ( ) ; 
dest • init ( ) ; 

25 

MyTransporter T = new MyTransporter () ; 
trans . init ( ) ; 

String MC = "mc"; 
30 T.addDestinationListener (MC, D) ; 



MyApplicationMediator AM = 
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new MyApplicationMediator ( ) ; 

AM.addPlacementListener (P) ; 
AM.addTopListener (P) ; 
AM-addRequestListener (T) ; 

AM.init () ; 

} 

} ' 

VI . Subsystem Behavior 

A. ViewCont roller Subsystem Runtime Behavior 

With reference now to Figure 39, a diagram 
illustrating runtime behavior of a ViewController 
subsystem is depicted in accordance with a preferred 
embodiment of the present invention. The runtime 
behavior of the ViewController subsystem 3900 is shown in 
Figure 39. This subsystem is the basic GUI building block 
and the primary mechanism for interacting with the user. 
The ViewController interface 3902 extends JTC interface 
3904. It defines the graphic components of an 
application and specifies methods for managing 
ViewListeners 3906, permissions, properties, resources, 
visibility and validity. It also specifies methods to 
refresh data. The ViewController is also responsible for 
handling refresh calls 3908 and updating the GUI 
accordingly* 

ViewController 3902 is responsible for communication 
of information to ViewListeners 3906. ViewController 
3902 knows the full semantics of the data model. One 
communication technique for sending information to 
ViewListeners 3906. is to fire a ViewEvent 3910 that the 
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listeners can interpret* The specification of the major 
and minor codes in ViewEvent 3910 directs the listeners 
as to what action to perform. Additional information in 
the form of a String or user-defined data object can be 
5 specified by the setData method. ViewController 3902 

also can provide named methods. Once a ViewEvent 3910 is 
consumed f it is not forwarded to other listeners* Another 
communications technique is to use property change events 
on the data model. Management of data and use of this 

10 approach is discussed explicitly in a later section. 
The actual implementation of ViewController 
interface 3902 is performed in the ViewControllerlmpl 
class 3912. A ViewControllerlmpl creates a panel 3914 
that allows interaction with the user. All AWTEvents 

15 3916 are sent to a user-defined subclass 3918, which 

extends the ViewControllerlmpl 3912. Java provides two 
built-in mechanisms for managing panels: the Panel class 
3920 that is part of the Java AWT and the Jpanel class 
3922 that is part of the com. sun. java. swing package. 

20 ViewControllerBaselmpl 3924 is a superclass of 

ViewControllerlmpl 3912, which abstracts these different 
panel mechanisms. 

ViewController subsystem 3900 is also responsible 
for validating data formats. ValidationRules 3926 

25 themselves are not part of the ViewController 3902, but 
the ViewController 3902 performs this validation between 
the input and output using the standard AWT methods such 
as getText and setText. The edit method inputs a 
transmittable string and outputs it in visible form 

30 (e.g., 1234 to $12.34) while the normalize method inputs, 
a string in visible form and converts it to 
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transmittable form (e.g., $12.34 to 1234). A failure in 
format conversion results in a ValidationRuleException 
3928. 

For instance, data starts out in a text field 
5 (component) in a ViewController (component) that derives 
from JPanel (container) . The value of the text field is 
retrieved and passed as a String to the validation rule. 
The result will be a validated and formatted string or an 
exception. In the former case, the textfield is 
10 redisplayed with the new contents AMD/ OR the data model 
is updated. In the latter case, some error message is 
displayed. 

With chaining, the results of each validation rule 
call are passed to the next validation rule. Processing 

15 will stop when the first exception is encountered (first 
exception first return (FEFR) ) or all validation rules 
have been processed. 

Turning next to Figure 40, steps in the operation of 
a ViewController subsystem, as viewed from a 

20 ViewControllerlmpl, are depicted in accordance with a 
preferred embodiment of the present invention. The 
process begins by implementing the ViewController 
interface (step 4000) . Thereafter, the JTC interface is 
implemented (step 4002) . Thereafter, specific methods 

25 are added for the ViewController (step 4004) . 

Thereafter, the GUI is created and composed (step 4006) . 
Thereafter, a reference to "yourself" is returned in 
getComponent (step 4008) . ViewControllerBaselmpl or any 
subclass of ViewControllerlmpl can return the particular 

30 component to be placed (by the PlacementListener ) in the 
getComponent () method) Thereafter, permission keys, 
resources, and properties are returned when requested 
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(step 4010) . 

The permission keys, resources, and properties are 
updated when requested (step 4012) . Internal AWTEvents 
are handled (step 4014) . Data fields are validated and 

5 formatted (step 4016) . ViewEvents are issued for 

semantic interpretation (step 4018) . The AWT thread is 
returned (step 4020) . Refresh calls are handled to 
update the GUI (step 4022). Data is accessed (step 4024). 
A determination is made as to whether the ViewController 

10 is still active (step 4026) . If the ViewController is 
still active, the process returns to step 4010. 
Otherwise, the process terminates for the 
ViewControllerlmpl . 

Additionally, a ViewController may be used to 

15 generate alternate views. For example, the application 
containing the view controller may be located on the 
server in which a placement listener is used to call a 
method in the ViewController to generate a presentation 
of a component in an alternate format, for example to be 

20 displayed in an HTML browser or an XML browser. In this 
example, the ViewController is on the server while the 
alternate view is displayed on the client. The 
PlacementListener has one method: placementEventPer formed 
that takes a PlacementEvent as a parameter. The 

25 PlacementEvent contains a major, minor, source 

ApplicationMediator and Component (from getComponent ( ) of 
the ViewController) . To use the alternate view, and 
without extending the PlacementEvent definition, it 
should be noted that to call for the alternate view, the 

30 ViewController needs to be accessed. Therefore, the 
ViewController can be accessed via the Object data; 
variable in the PlacementEvent. 



85 

Docket No. AT9-99-339 



Alternate views, may include, for example, text for 
text based terminals or event data for a debug monitoring 
display, also, any user input from HTML or other view 
comes back to ApplicationMediators and ViewControllers as 

5 refresh data. The ApplicationMediator may either display 
the next ViewController or have current ViewController 
redisplay the entered user input. 

With reference now to Figure 41, a flowchart of an 
alternate view process is depicted in accordance with a 

10 preferred embodiment of the present invention. The 
processes of the present invention may be applied to 
other types of applications other than clients. For 
example, the process of the present invention may be 
applied to create applications for use on a server. In 

15 Figure 41, the process of the present invention is used 
to generate an alternate view in which the containers are 
output in the form of HTML for transfer to a client over 
a communications link. 

In Figure 41, the application mediator receives a 

20 ViewEvent from a ViewController (step 4100) . A 

determination is made as to whether the ViewController 
should be placed in the client (step 4102) . If the 
ViewController should not be placed, then the process 
terminates. If the ViewController should be placed, then 

25 a PlacementEvent is created with the proper major code 
(step 4104) . This PlacementEvent is then fired (step 
4106) . A PlacementListener is invoked (step 4108) . The 
PlacementListener receives the PlacementEvent (step 4110). 
A determination is made as to whether the major code is 

30 for a placement HTML (step 4112) . If the major code is 
for an HTML placement then a call is made by the 
PlacementListener to toHTML method in the ViewController. 
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(step 4114) . In response, the view components are 
translated into HTML components (step 4116) . An HTML 
output is generated (step 4118) . This HTML output is 
then sent to the client browser for display (step 4120) 
5 with the process then terminating. 

With reference again to step 4112, if the major code 
does not indicate the use of HTML as an alternate view, 

v.- 

then a determination is made as to whether the major code 
identifies another alternate view (step 4122) . If 
10 another alternate view is not indicated by the major 
code, then the process terminates. Otherwise, an 
alternate view is created and placed (step 4124) with the 
process then terminating. " The other alternate view may 

'asp 

! J3 take various forms, such as, for example, XML. Step 4122 

;]j 15 may be iterated for a number of different alternate views 

H that may be provided through the ViewController 

m component. In this manner, the architectural pattern of 

l O the present invention may be applied for use on a server. 

u- b This mechanism is used by a PlacementListener to call a 

□ 20 method in a ViewController to create an HTML version of 

j5 an existing screen. The mechanism for creating the HTML 

if view is application dependent/screen dependent in the 

depicted examples. 

An example of how to configure JTC with alternate 
25 views on a server is given. The deployment of JTC on the 
server is under the control of a servlet. Since, as 
described in this example, HTML is in the client, when a 
client browser invokes a URL submit, the web server 
obtains the request and passed control to a servlet. The 
30 servlet obtains a key/value pair list of values entered 
in the HTML client. This list is passed to the 
ViewController alternate view being displayed. The 
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ViewController iterates over the list and applies its 
ValidationRules. If a ValidationRuleException is 
generated, the servlet indicates an error message to the 
HTML client. If a successful result is obtained, the 
5 ViewController will generate a ViewEvent, as mentioned 
above, causing the alternate view cycle through the 
ApplicationMediator and PlacementListener to repeat. The 
primary benefit being that one source code system can be 
maintained and versioned to produce multiple client 
10 channel views. 

Turning now to Figures 42 and 43, diagrams detailing 
processes within the ViewController subsystem are 
depicted in accordance with a preferred embodiment of the 
present invention. The code illustrated is Java code in 
15 the depicted examples. 

The creation of a ViewEvent based on an ActionEvent 
from the Java AWT is shown in Figure 42. The 
actionPerformed method detects the type of action and 
constructs a corresponding ViewEvent. The source of the 
20 ActionEvent was a click of the nextButton. This is 
detected and the ViewEvent ve is created with the 
self-referential "this" pointer being passed in. The 
major field is set to NEXT, a predefined type, and the 
event is fired. ActionPerformed has done its job and 
25 returns . 

Figure 43 shows how a ViewEvent is processed by a . 
Before any events can be processed, an object has to add 
itself as a listener for the appropriate ViewEvents. In 
this case, the listener is added to the 
30 customerDetailsViewController . The method 

processViewEvent may carry out some initial action for 
all events and then a switch statement is used to 
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separate out all of the major code fields of interest. 
The comments inside the switch indicate where different 
actions can be performed for different events. A 
complete list of predefined major event codes is given in 

5 Figure 44 ♦ 

Validation rules either use edit to convert from a 
transmittable string to the viewable format or use 
normalize to convert from a viewable format to a 
transmittable string. Figure 44 shows how a text field 

1Q representing a social security number can be put into 
visual form (e.g., 123-45-6789) by calling 
SocialSecurity.edit . Since a ValidationRuleException 
will be thrown if the conversion is unsuccessful, this 
call is embedded in a try statement with a catch for 

15 exception handling. In a comparable manner, Figure 46 

shows how the visual format for a social security number 
can be converted back to a transmittable format. 

It is possible to build a chain of validation rules. 
Figure 47 illustrates the application of two edit rules, 

20 range checking (that is, the value is within specific 
limits) and formatting for viewing. The separate rules 
are assigned to string values named range and money. 
This string values are then put into an array of strings. 
The transmittable form of the data is stored in value. 

25 The method applyEdits applies both validation rules to 

this data; if any exception occurs, it is handled by the 
catch portion of the try statement. The setText method 
from the Java AWT is used to redisplay the formatted 
data . 

30 Two techniques exist for creating the 

ViewControllerBaselmpl class: by inheritance and by 
delegation. Figure 48 illustrates inheritance where the 
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ViewControllerBaselmpl is a subclass of JPanel from the 
Java com. sun. java. swing package. Notice that the 
operation getComponent simply returns a pointer to 
itself* When delegation is used, as shown in Figure 49, 

5 ViewControllerBaselmpl implements the ViewController 

interface. The constructor for a user defined XYZ class 
creates a new instance, called xyz. Operations from the 
ViewCohtrollerBaselmpl class are translated into 
corresponding operations from the XYZ class. Three 

10 operations are illustrated: getComponent, setEnabled, and 
setVisible. 

B. ApplicationMediator Subsystem Runtime Behavior 

Turning now to Figure 50, a diagram illustrating 
runtime behavior of an ApplicationMediator subsystem is 

15 depicted in accordance with a preferred embodiment of the 
present invention. The runtime behavior of the 
ApplicationMediator subsystem 5000 is shown in Figure 50. 
ApplicationMediator 5002 manages all the major components 
of the thin client architecture JTC 5004. This includes 

20 managing instances of ViewControllers 5006 and 

ApplicationMediators 5008, and adding, firing, or 
removing instances of PlacementListeners 5010 and 
TopListeners 5012. The implementation of the interface 
of ApplicationMediator 5002 is carried out by the class 

25 ApplicationMediatorlmpl 5014. An application dependent 
subclass 5016 of ApplicationMediatorlmpl 5014 actually 
processes the various events in the subsystem 5000. 
ApplicationMediator subsystem 5000 can process ViewEvents 
5018 generated by ViewController 5020 and it can generate 

30 its own ViewEvents if necessary. Requests for actions to 
be performed by the server result in RequestEvents 5022, 
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A subclass is needed to implement a state machine 
for correctly ordering operations. Sample operations 
include which ViewControllers 5006 to allocate or which 
to make visible, when to fire or re-fire a ViewEvent, 
5 when to fire a RequestEvent 5022, and when to fire a 
TopEvent 5012. 

The typical sequence of actions when a ViewEvent is 
received is to request a PlacementListener 5010 to place 
another ViewController 5006 on the screen, to request 

10 TopListener 5012 to do something with the operating 
system desktop, and to fire RequestEvents 5022 for 
fulfillment by a server. Refresh calls are propogated to 
the ViewControllers 5006 and ApplicationMediators 5008, 
All JTC objects allocated are returned via the getJTCs 

15 method. 

Turning next to Figure 51, a diagram illustrating 
Event threading support is depicted in accordance with a 
preferred embodiment of the present invention. Figure 51 
illustrates the two styles of AWT Event threading support. 
20 This occurs when a ViewController 5100 generates a 
ViewEvent 5102 that is to be processed by the 
ApplicationMediator 5104, Style 1 uses a queuing 
mechanism while style 2, the default, uses thread 
dispatching. 

25 The following steps occur when using the queuing 

approach: create a sleeping thread during initialization, 
when a ViewEvent arrives place it in a queue 5106 of 
ViewEvents, notify the sleeping thread and return to the 
calling ViewEvent thread (typically an AWT Event thread) . 

30 The run() method 5108 wakes up to process the ViewEvent by 
taking it off the queue- The processViewEvent method is 
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then called. Subclasses override this method to handle the 
ViewEvent directly. 

The second mechanism is to use thread dispatching 
directly. When a ViewEvent arrives, create and start a 
5 thread 5110 passing it the ViewEvent and return to the 

calling ViewEvent thread. Add the new thread to a list to 
provide a handle to access it. This new thread invokes the 
processViewEvent method which subclasses can override to 
handle the ViewEvent directly. 

10 With reference now to Figure 52, a flowchart of a 

process used in designing and executing an 
ApplicationMediator is depicted in accordance with a 
preferred embodiment of the present invention. The 
process begins by implementing an ApplicationMediator 

15 interface (step 5200) . Thereafter, the JTC interface is 
implemented (step 5202). ApplicationMediatorlmpl methods 
are added (step 5204) . ViewControllers are created using 
the initViewController method (step 5206) . 

Thereafter, initApplicationMediator are used to 

20 create other ApplicationMediators as necessary (step 

5208) . Thereafter, the process listens for ViewEvents and 
RequestEvents (step 5210) . A determination is made as to 
whether a ViewEvent has been received (step 5212) . If a 
ViewEvent has not been received, the process returns to 

25 step 5210. Otherwise, a request is made to a 

PlacementListener to put another ViewCont roller on the 
screen (step 5214) . This step basically results in the 
display of another ViewController' s getComponent ( ) on the 
screen* 

30 Next, the TopListener performs desktop operations as 

appropriate (step 5216) . The ApplicationMediator also 
fires the appropriate RequestEvent to server (step 5218) . 
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Refresh calls are sent to ViewControllers and 
ApplicationMediators (step 5220) . All JTC objects 
allocated are returned (step 5222) with the process then 
returning to step 5210. 

5 C. Placement Subsystem Runtime Behavior 

With reference now to Figure 53, a diagram 
illustrating runtime behavior of the Placement subsystem 
is depicted in accordance with a preferred embodiment of 
the present invention. The runtime behavior of the 

10 Placement subsystem is 5300 shown in Figure 53. The JTC 
architecture separates out the actions of ViewEvent 5302 
creation (done by ViewController, 5304), view ordering 
(done by ApplicationMediator, 5306) , and view placement 
(done by PlacementListener, 5308) . A PlacementEvent 5310 

15 is used to notify a PlacementListener that a 

ViewController needs to be adjusted on the screen. 

The state of a PlacementEvent includes a major code, 
which is the primary identifier of the PlacementEvent. A 
minor code serves as the secondary identifier of the 

20 PlacementEvent. The PlacementEvent state also includes a 
source identifying the source object that creates the 
Event. A j ava . awt . Component also is present in the 
state that identifies the component to be placed. The 
state also contains consume, which identifies whether an 

25 PlacementEvent has been consumed. A consumed 

PlacementEvent will cause the JTC to stop processing the 
PlacementEvent immediately. Additionally, the 
PlacementEvent state also may contain other data, which 
may be, for example, a reference to generic object data 

30 that specifies placement information specific to the 
application. 
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Each PlacementEvent 5310 contains a placement type 
(ADD, ADDALL, REMOVE , REMOVEALL , MODIFY, SHOW, DONE, 
FREEZE , and REPAINT are predefined) , a minor code for 
additional information, the sender of the event, the 
5 component, and provisions for additional generic data. 
Typically an ApplicationMediator 5306 will assign the 
appropriate major code, find the component using the 
getComponent method, create PlacementEvent 5310 making 
itself the sender, and fire the placement event. The 
10 PlacementListener 5308 uses placementEventPerf ormed to 
process PlacementEvent 5310 based on the placement type 
and the source of the event. 

Details of the steps discussed above are now 
0 examined through various examples of Java code. The 

15 creation of a PlacementEvent from an ApplicationMediator 
^ is shown in Figure 54. There are three parameters to a 

1] PlacementEvent constructor: the object (referenced by 

y '"this") creating the event, the component involved, and 

^ the major code. In this example, the major code is set 

H 1 20 to ADD and the component comes from 

3 customerDetailsViewController . After the PlacementEvent 

f is created, it is fired by the ApplicationMediator. 

The PlacementEvent is processed by a 
PlacementListener, as shown in Figure 55. The method 
25 placementEventPerformed decides on the appropriate action 
based on the major code and the source. In this example, 
the major code is ADD, which is one of the cases in a 
switch statement. If the source is Pref erencesAM, then 
the PlacementEvent component is centered in panel 1, 
30 otherwise it is added to panel2. 

Turning now to Figure 56, a flowchart of a process 
used in processing a PlacementEvent is depicted in 
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accordance with a preferred embodiment of the present 
invention. The process begins by one or more 
ViewControllers responding to getComponent (step 5600) . 
After, ApplicationMediators control the ordering of the 
5 ViewController (step 5602) , The ApplicationMediators 

fire PlacementEvents (step 5604) . The PlacementListeners 
select the proper implementation and place the Component 
on the screen (step 5606) with the process terminating 
thereafter. 

10 D. TopListener Runtime Behavior 

With reference now to Figure 57, a diagram 
illustrating runtime behavior for a TopListener subsystem 
is depicted in accordance with a preferred embodiment of 
the present invention. The runtime behavior of the 

15 TopListener subsystem 5700 is shown in Figure 57. 

TopListener 5702 performs generic operations on the 
business desktop, as specified by a TopEvent 5704. The 
TopEvent and TopListener have several functions. One 
function is interaction with the host environment (i.e. 

20 for a Java application — the operating system) , with the 
host environment services (i.e. other applications on the 
operating sytem) , with the application enabler (i.e. the 
Netscape browser and its status line or maybe aspects of 
the Java Virtual Machine), and with host environment 

25 policies (i.e. how is shutdown handled, how are error 
messages handled) . The hosting client desktop 
environment is an embodiment of one or more of these 
items . 

The TopListener is also used by the JTC application 
30 to send events to itself. For example, based on some 
heuristic, the TopListener may decide to change the 
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Destination from one using sockets to one using URLs. 
Or, a second destination may be added to perform logging. 
The permissions also may be altered. The TopListener may 
use a heuristic to decide to invoke hookJTCs and hookAWTs 
5 on the application and start tracing. Thus, in addition 
to accessing hosting services, the TopListener also 
allows self alterable JTC actions to occur on the JTC 
application. 

TopEvent 5704 contains a major code, a minor code, 
10 the source that created the event, a consumed event that 
causes the JTC to stop processing it as soon as possible, 
and a generic data object. There are predefined 
constants for EXIT, BROWSER, TITLE, STATUS, OS, TRACE, 
DEBUG, LOG, HOOKAWT, and HOOKJTC. ApplicationMediator 
15 5706 uses addTopListener to pass itself to the 

TopListener for later callback in the topEventPerf ormed 
method. 

Details of the steps discussed above are now 
examined through various examples of Java code. With 

20 reference now to Figures 58-60, Java code used in a 

TopListener is depicted in accordance with a preferred 
embodiment of the present invention. The creation of an 
ApplicationMediator and the adding of a PlacementListener 
is shown in Figure 58. The creation and firing of a 

25 TopEvent in an ApplicationMediator is shown in Figure 59, 
Java code illustrating the callback to a TopListener with 
a TopEvent and inspecting the TopEvent for semantic 
interpretation is shown in Figure 60. This method uses 
the major code to separate out the various cases and to 

30 perform the appropriate actions. 



96 



Docket No. AT9-99-339 

E . RequestEvent Subsystem Runtime Behavior 

The RequestEvent subsystem provides a mechanism for 
sending messages between various components in the 
architectural pattern of the present invention. This 

5 subsystem provides a mechanism to access data and to send 
data between components, such as an ApplicationMediator, a 
Transpdrter, and a Destination. With reference now to 
Figure 61, a diagram illustrating runtime behavior of a 
RequestEvent subsystem is depicted in accordance with a 

10 preferred embodiment of the present invention. The runtime 
behavior of the RequestEvent subsystem 6100 is shown in 
Figure 61. An ApplicationMediator 6102 receives a 
ViewEvent 6104 from a ViewController 6106 and determines 
it has to issue a RequestEvent 6108 to an appropriate 

15 service provider. RequestEvent 6108 can either be 

synchronous or asynchronous in the depicted examples. 
RequestEvent 6108 has fields for a major code (a request 
family), a minor code (a specific request), a user-defined 
version, a status string showing the current stage of 

20 processing, a possible consume event that will cause the 
JTC application to stop processing it as soon as 
possible, and a data field for a generic data object. 

ApplicationMediator 6102 calls f ireRequestEvent . A 
Transporter, which is one example of a RequestListener 

25 6110, is responsible for forwarding all RequestEvents to 
one or more destinations based on the major code. 
ApplicationMediator 6102 will be called back in one of two 
ways: requestResponse to indicate success and passed a 
RequestEvent that may have new data or requestException to 

30 indicate failure and passed a RequestException with the 
reason for failure. 
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With reference now to Figure 62, Java code 
illustrating the creation of RequestEvent, setting its 
major and minor codes, and firing an asynchronous 
RequestEvent from an ApplicationMediator is depicted in 

5 accordance with a preferred embodiment of the present 
invention. Details of the steps discussed above are now 
examined through various examples of Java code. 

The creation, firing, and callback of a RequestEvent 
in an ApplicationMediator is shown in Figure 62. After 

10 the RequestEvent r is created, the major and minor codes 
are set to "Loans" and "SubmitCustomerlnf o" in this 
example. The event r is fired asynchronously by the 
ApplicationMediator. This is done inside of a try 
statement so that any RequestException can be caught and 

15 processed appropriately in Figure 63. Later there will 
be a callback to the ApplicationMediator by 
requestResponse to indicate successful processing of the 
RequestEvent or by requestException to indicate failure 
processing the RequestEvent in Figure 64. 

20 With reference now to Figure 65, a flowchart of a 

process for using a RequestEvent is depicted in accordance 
with a preferred embodiment of the present invention. The 
process begins by an ApplicationMediator receiving a 
ViewEvent from a ViewController (step 6500) . Thereafter, 

25 the ApplicationMediator creates a RequestEvent specifying 
the major code, and a version (step 6502) . Thereafter, a 
f ireRequestEvent is issued to cause the RequestEvent to be 
sent to a service provider (step 6504) . Based on the 
major code, the Transporter forwards the RequestEvent to 

30 one or more Destinations (step 6506) with the process 
terminating thereafter. 
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F. Transporter Subsystem Runtime Behavior 

The Transporter subsystem is used to map and send 
various RequestEvents to different Destinations . With 
reference now to Figure 66, a diagram illustrating runtime 
5 behavior of a Transporter subsystem is depicted in 
accordance with a preferred embodiment of the present 
invention. The runtime behavior of the Transporter 
subsystem 6600 is shown in Figure 66. The main task of 
the Transporter class 6602 is to map RequestEvents 6604 

10 received from an ApplicationMediator 6606 to the 

appropriate Destinations. A Destination 6608 is added to 
the Transporter 6602 by using addDestinationListener . 
Each listener is associated with a destination major code. 
In the depicted examples, multiple destinations can listen 

15 for the same major code. Events are processed in a 
First-In First-Out, First Exception First Return 
(FIFO/FEFR ) 6610 fashion in these examples. It is 
possible to have one Destination pass a message to 
another Destination. RequestExceptions 6612 are used to 

20 handle failures. 

Turning now to Figure 67, Java code illustrating 
creation of a Transporter and adding it as a 
RequestListener is depicted in accordance with a preferred 
embodiment of the present invention. The Transporter t 

25 and ApplicationMediator am are both created. The method 
addRequest Listener is called to add t as the transporter 
for am. 

G. Destination Subsystem Runtime Behavior 

A Destination subsystem provides a number of 
30 different functions, such as, for example, locating a 
server, creating low level protocols, such as sockets, 
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URLs, RMI, and files for network transport. Additionally, 
the Destination subsystem provides a mechanism to 
communicate with different servers, such as EJB, servlets, 
web servers, application servers, and other legacy 

5 systems. Additionally, message formats are provided to 

turn RequestEvents and data into formats for the target or 
server. Additionally, the Destination subsystem will 
finish the job in an appropriate amount of time or cancel 
the operation in response to a timeout. Additionally, the 

10 Destination subsystem also determines how many times a 
connection should be retried. Additionally, the 
Destination subsystem caches data until it becomes stale. 
Additionally, the Destination creates all data model 
objects used in the JTC client application. Pre-processed 

15 and post-processed RequestEvents are also logged along 
with locating and creating objects for processing 
requests . 

With reference now to Figure 68, runtime behavior of 
a Destination subsystem is shown in accordance with a 

20 preferred embodiment of the present invention. In 

Destination subsystem 6800, Destination class 6802 and its 
implementation, Destinationlmpl 6804, handles all the 
details to locate server 6806, use various transport types 
and server types 6808, and, in general, keeps track of 

25 where objects are. Destination codes are either named, 
given a wildcard value (*, means interested in all 
requests) or given a priority value {!, means interested 
in all requests and has priority) . Some special cases of 
priority are FIRST, SECOND, NINTH. DON' TjCARE is a 

30 special case of wildcard that indicates even if a 

RequestException is present, do not stop processing and 
send the request to the Destination. 
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Details of the steps discussed above are now examined 
through a Java code example. In Figure 69, a diagram of 
Java code for creation of a Destination and adding it as a 
destination listener is depicted. Turning now to Figure 
5 69, Java code illustrating creation of a Transporter and 
adding it as a RequestListener is depicted in accordance 
with a preferred embodiir^nt of the present invention. The 
Destination d and the Transporter t are both created. The 
method addDestinationListener is called to add d as a 

10 destination listener for transporter t using the major 
code "Loans.'' 

Turning next to Figure 70, a diagram illustrating 
Java code for creating Destinations with wild card, 
priority and normal major codes, firing a RequestEvent, 

15 and a report of the expected results is depicted in 
accordance with a preferred embodiment of the present 
invention. Transporter t and WildDestination d are created 
and d is added as a WILDCARD destination listener. 
Destination d is now assigned to be a EJBDestination and 

20 added to t with the major code of "Loans. " Destination d 
is then assigned to be a PriorityDestination and added to 
t with the major code of PRIORITY . Finally d is assigned 
to be a LoggerDestination and added to t with the major 
code of DON' T_CARE . At a later time, the RequestEvent r 

25 is created with the major field of "Loans" and is fired. 
Event r will be sent to PriorityDestination 1 st , 
EJBDestination 2 nd , WildDestination 3 rd , and 
LoggerDestination last. Event r reaches the first three 
destinations only if no RequestExceptions are thrown; it 

30 reaches LoggerDestination regardless of any 
RequestExceptions . 
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VII . Component Details and Applications 
A. use of getJTCs 

The architectural pattern of the present invention as 
5 all major objects in a JTC application implement the JTC 
interface. This includes the driver programs that 
launches the Application, or applet. This interface allows 
referencing of all objects with a consistent Java type. 
The behavior includes, clear, exit, getJTCs, init, 
10 isEnabled, setEnabled, and toString. Interfaces extending 
JTC are ViewController, ApplicationMediator , and 
Destination. ViewController Impl, ApplicationMediator Impl, 
Transporter, and Destinationlmpl are classes implementing 
JTC. Consider a program called "program" that implements 
15 all of '"significant" the Java and user defined interfaces. 
A significant interface is an interface in which the 
"program" is interested in receiving callbacks. The 
getJTCs method causes each JTC object to return a list of 
other JTC objects that the JTC object creates. This 
20 method may be used by the "program" to iterate over this 
list and inspect each object's types and add the 
"program" as a listener to all of the object's significant 
event listener types. 

As a result, the system may be reconfigured through 
25 this mechanism. For example, the Transporter may be 

disabled or a priority Destination may be added using 
this method. Further, this method provides a mechanism 
for non- intrusive logging, tracing, debugging, and 
monitoring. This is particularly significant when a 
30 ViewController is encountered. In addition to adding the 
^program" as a ViewListener, the getComponent method is 
called to retrieve a j ava . awt . Component . The 
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java.awt .Component object is at the top of the Java 
graphics Component hierarchy. The "program" recursively 
looks at this hiearchy, traverses it, and add the 
"program" as listeners for all significant Java AWTEvent 

5 and JFC events. Using reflection, any Java object that is 
returned can be inspected and "hooked" for significant 
interface events. The "program" can do various tasks with 
these events such as trace, remotely display the events, 
reroute the client application to a new server, and record 

10 user statistics; all non-intrusive to the application in 
terms of writing additional code to support this 
capability. 

With reference now to Figure 71, a diagram of Java 
code used for accessing, identifying type and recursively 

15 attaching JTC, AWT and JFC listeners to processing 

accessible JTC, AWT and JFC programs and objects JTCs is 
depicted in accordance with a preferred embodiment of the 
present invention. In particular, all JTCs are found and 
put into a Java Vector. Additional actions are performed 

20 depending on the type of JTC, such as adding 

RequestListeners for ApplicationMediators or adding 
Viewlisteners for ViewControllers . This function 
continues processing all JTC objects in a recursive 
manner . 

25 The function is named hookJTCs and it starts out at 

the root JTC, The Vector jtcs is initialized to null. 
The method get JTCs is used to find all JTCs of the root. 
If an exception occurs or no JTCs are found, the function 
is exited. 

30 Assuming the vector is not empty, each JTC object in 

the vector is processed in turn. This code illustrates 
the "program" adding itself as a RequestListener and 
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ViewListener to ApplicationMediators . This code 
issustrates the "program" adding itself as a ViewListener 
to ViewControllers Although not shown in the code, other 
JTC objects , such as a Transporter, might be hooked by 
5 the "program". The function hookJTCs is called recursively 
at this point resulting in the JTC hierarchy being 
processed in a depth-first then breadth-first fashion. 

With reference now to Figure 72, an example of a test 
program is depicted in accordance with the preferred 
10 embodiments of the present invention. In Figure 71, the 
main program Testl.java stores a static reference to 
itself so that a launcher can call getJTCsO and hook the 
application. Figure 73 is a diagram of Java code used for 
attaching AWT and JFC listeners to AWT and JFC containers, 
15 components and beans depicted in accordance with a 

preferred embodiment of the present invention. Figure 74 
is a diagram of Java code used for attaching AWT and JFC 
listeners to AWT and JFC components (java.awt. Button, 
com. sun. swing. java.JBut ton and com. and 
20 com. sun. java, swing. JTextField) depicted in accordance with 
a preferred embodiment of the present invention. 

With reference now to Figure 75, a flowchart of a 
process for accessing objects is depicted in accordance 
with a preferred embodiment of the present invention. The 
25 process begins by receiving a call to get JTCs and get the 
vector of JTC object (step 7500) . A determination is then 
made as to whether a return is null (step 7502) . If the 
return is null, the process then returns. This indicates 
that no objects are present. Otherwise, a determination 
30 is made as to whether more entries are present (step 

7504) . If more entries are present, then an unprocessed 
entry is used (step 7506) . Thereafter, a determination is 
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made as to whether the entry is an instance of an 
ApplicationMediator (step 7508) . If the instance is that 
of an ApplicationMediator, the "program" is added as a 
ViewListener (step 7510) . 

The process then adds the "program" as a 
RequestListener (step 7512) with the process then making 
a recursive call and starting at step 7500. 

With reference again to step 7508, if the entry is 

t 

not an instance of an ApplicationMediator, a 
10 determination is made as to whether the instance is that 
of a ViewCont roller (step 7514). If the object for the 
entry is an instance of a YiewController, the "program" 
is added as a ViewListener. Thereafter, a hookAWTs with 
the component returned from the ViewController' s 
15 getComponent method is performed (step 7518) . This step 
is described in more detail below with respect to Figure 
77. The process then makes a recursive call and starts 

at step 7500. 

With reference again to step 7514, if the instance 
20 is not a ViewController, then a determination is made as 
to whether the object for the entry is an instance of a 
Transporter (step 7520). If the object is an instance of 
a Transporter, the "program" is added as a 
RequestListener (step 7522) with the process then making 
25 a recursive call and starting at step 7500. 

With reference again to step 7520, if the object is 
not an instance of a Transporter, a determination is made 
as to whether the object is an instance of a component 
(step 7524) . If the object is an instance of the 
30 component, the process performs hookAWTs with the 

component (step 7526) with the process then proceeding to 
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step 7504, Step 7526 is used to hookAWTs to a component. 
With reference again to step 7524, if the object is not 
an instance of a component/ the process then returns to 
step 7506 to select another entry for processing. 
5 With reference again to step 7504, if more entries 

are not present, then a non-intrusive program, the 
"program", is run to listen for events and debug, log, 
trace, and/or simulate (step 7528) . The debug, log, 
trace, and/or simulate functions may be performed using 
10 presently available techniques for debugging, logging, 
tracing, and/or simulating applications. 

3 B • Recursive Processing of a Component Hierarchy 

J A component hierarchy is a recursive data structure 

Uj 15 in the sense that, if the component is a container, then 

V It may contain other components, which in turn may 

fy contain other components, and so forth. Consider the 

hierarchy shown in Figure 76. Component A 7 600 is a 
^ container that is a list of three other components: Al 

ij 20 7602, A2 7604, and A3 7606. Al 7602 is a container with 

two components All 7608 and A12 7610), and A3 7606 is a 
a container with two components (A31 7612 and A32 7614) . 

The components All 7608, A12 7610, A2 7604, A31 7612, and 
A32 7614 are not containers. The goal of a "hook" 
25 algorithm is to find all the components in the hierarchy 
and "hook" each "child" component to the "program" 
component in the sense of adding appropriate listeners 
for events, while passing through the "parent" container. 
Since the component hierarchy is a recursive data 
30 structure, a recursive algorithm most easily processes 

this hierarchy. It starts at the root component, A BT00, 
and determines if it- is a container, it proceeds to 
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process the first component in the container, Al BT02, 
using the same algorithm. Al 7602 is also a container, 
so the algorithm is applied recursively to the component 
All 7608, All is not a container, so a M hook" to this 
5 component (that is, appropriate listeners) is added. 

Control now returns to the algorithm processing Al 7602. 
There 4-S another component in the list of Al 7602, namely 
A12 7610, and it is processed recursively. A12 7610 is 
not a container, so it adds listeners appropriate for its 

10 type. No more components exist in the list of components 
for Al 7602, so it has now added listeners for all its 
children. Control returns back to the algorithm 
processing parent A. 

Component A proceeds to the next item in its 

15 container, namely A2 7604. A2 7604 is not a container, 

so it adds listeners appropriate for its type. A now has 
added all the appropriate listeners for its children, Al 
7602 and A2 7604, and all of their descendants. A3 7606 
is processed next and, in a manner analogous to Al 7602, 

20 it adds listeners for its two children, A31 7608 and A3 2 
7614. Listeners have been added for all of the 
descendants of A 7600, so the algorithm terminates. 

With reference now to Figure 77, a flowchart of a 
process for performing hookAWTs is depicted in accordance 

25 with the preferred embodiment of the present invention. 
This process is used to hookAWTs to a component. The 
processes depicted in Figure 77 are a more detailed 
description of steps 7518 and 7526 in Figure 75. The 
process begins by determining whether the component is a 

30 container (step 7700) . If the component is a container, 
then a list of the components in the container is 



107 

Docket No. AT9-99-339 

obtained (step 7702) . Thereafter, a determination is 
made as to whether more components are present in the 
list (step 7704) . If more components are present in the 
list, then the next component is selected for processing 
(step 7706) . A recursive call to D is performed (step 
7708) . This step results in the process returning to 
step 7J00 and performing the steps as described above. 
Thereafter, the process hooks the component (step 7710) . 
Then, the process returns to step 7704 to determine 
whether more components are present in the list. 

If more components are not present in the list, then 
the component is hooked (step 7712) with the process and 
returns . 

With reference again to step 7700, if the component 
is not a container, then the process also proceeds to 
step 7712. Step 7710 and step 7712 are described in more 
detail below in Figure 78. 

With reference now to Figure 78, a process for 
hooking a component is depicted in accordance with the 
preferred embodiment of the present invention. Figure 78 
is a more detailed description of the processes performed 
in step 7710 and 7712 in Figure 77. The process begins 
by determining whether the component is an instance of a 
button (step 7800) . If the component is an instance of a 
button, the button is added as an action listener (step 
7802) (with the process then returning) . An Action 
Listener listens for events generated by Button, List, 
Menultem, and TextField, all objects that can be part of 
the user interface. The event is handled by the method 
actionPerf ormed . 

With reference again to step 7800, if the component 
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is not an instance of a button, a determination is made 
as to whether the component is an instance of a JButton 
(step 7804). Button is an object built using the AWT. 
JButton is an object built using the Swing library. 
5 Swing components typically provide greater platform 
independence. If the component is an instance of a 
JButton, then the JButton is added as ActionListener, a 
ChangeListener, and an ItemListener (step 7806) . A 
ChangeListener listens for events generated by JFC 
10 components when their internal state has changed. The 
event is handled by the method stateChanged. 

An ItemListener listens for events generated by 
Checkbox, CheckboxMenuItem, Choice, and List, all objects 
that can be part of the user interface. The event is 
15 handled by the method itemStateChanged. 

With reference again to step 7804, if the component 
is not an instance of a JButton, a determination is made 
as to whether the component is an instance of a component 
(step 7808) . If the component is an instance of a 
20 component, then the component is added as an 

ActionListener and a CareListener (step 7810) , with the 
process returning thereafter. A CaretListener listens 
for events generated by objects that contain text cursor 
positions (caret) and the caret changes in the position 
25 of text. The event is handled by the caretUpdate method. 

With reference again to step 7808, if the component 
is not an instance of a component, a determination is 
made as to whether the component is an instance of other 
AWT/Swing/Bean types in Java (step 7812) . If the 
30 component is an instance of these other types, then the 
component is added to all event types generated by the 
component, with the process returning thereafter. If the 
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component is not an instance of these other types, the 
process then returns. 

The getJTCs and getAWTs algorithms are easily 
extended to other object types and hiearchies by brute 
5 force coding of the "instanceof / addListener" tests or 
by using reflection on the objects to "search for 
interfaces, search for interface methods, addListener" as 
reflection supports. 

10 C. Management of Data Objects 

User interaction triggers ViewEvents to perform a 
variety of tasks. These include system tasks (e.g., open, 
close, cancel, etc.), status tasks (e.g., various 
messages), navigation tasks (e.g., next, previous, first, 

15 last, etc.), data tasks (e.g., add, delete, modify, 

etc.), assist tasks (e.g., search, find, help, etc.) and 
live (streaming) tasks (e.g. fast, medium, delay, timer, 
on, off, high, low, etc.). 

Some tasks can be performed locally, but others are 

20 sent to a service fullfillment provider (the Destination) 
in the form of a RequestEvent containing appropriate data. 
Data is returned, often different than the data sent, and 
refresh is used to change what the user is viewing. 

Details of the steps discussed above are now examined 

25 through various examples of Java code. With reference now 
to Figures 79-82, diagrams of Java code for use in 
managing data objects is depicted in accordance with a 
preferred embodiment of the present invention. Passing 
data for the main program to ApplicationMediators is shown 

30 in Figure 79. The ApplicationMediator ami and the data 
object named data are created. By using the refresh 
method, the main program passed this data into the 
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ApplicationMediator . Refresh accepts any data object 
regardless of the number or shape of objects. It is 
because the data type definition is "Object data;" that 
JTC data support is neutral to the actual classes and 
5 interfaces of the data models being used. It is because 
the refresh method uses a data type definition "Object 
data;" that additional data models can readily be 
integrated into a JTC client application with minimal 
effort and side effects. The ApplicationMediatorlmpl 
10 passes the refresh on to all ApplicationMediators and 
ViewControllers . 

Alternatively, if the results of a RequestEvent 
contains changed data, the ApplicationMediator can 
initiate the refresh on to all ApplicationMediators and 
15 ViewControllers . 

The code in Figure 80 illustrates how a 
ViewController would handle data that uses the an example 
key-value pair data model. The first refresh function 
simply receives the data as type Object and type casts it 
20 to type KeyValue in a call to the worker refresh function 
of the key-value data model. The refresh of key-value 
pairs calls the AWT method setText for each of the 
textfields and then calls repaint () to change the user 
display (validate () followed by repaint () can also be 
25 used) . The code in Figure 81 illustrates how this top 

level refresh method can input any object and route it to 
a more particular version of refresh by detecting the type 
of data and casting it to a more specific type. The types 
Vector, KeyValue, and XMLData are shown, but others can be 
30 added. Figure 82 illustrates the processing of data in 
the form of a Vector where the first element is of type 
Customer and the second element is the ID. These two 
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values are extracted from the vector, cast and then 
assigned to the appropriate fields by using setText* A 
repaint updates the screen* 

Although the Destination locates, creates and 
5 packages these data types, the ViewController also knows 
the syntax of the data layout and packaging and the 
semantics of the data model. 

ApplicationMediators and ViewControllers can also 
bypass the normal JTC ViewEvent notifications when data 

10 has changed. For example, refresh can use an implicit 
data model (i.e. String, Integer), a user defined data 
model (described above) , named methods in the 
ViewController (less portable) and traditional Java 
property change event notifications. Further, live data 

15 models (i.e. streaming media, asynchronous device input) 
can also be incorporated easily. It is because JTC uses 
the data type "Object data;" and because the refresh 
method uses a data type definition "Object data;" that 
additional data models, event notifications, data access 

20 and data update differences can readily be integrated 
into a JTC client application with minimal effort and 
side effects - the GUI parts of the ViewController, 
ValidationRules, ApplicationMediators, ViewEvents, 
RequestEvents, TopEvents, PlacementEvents / TopListeners, 

25 and PlacementListeners do not have to change. Only small 
parts of the ViewController and Destinations need 
modification. This variety of techniques is illustrated 
next in Figure 83. 

One way for the ViewController 8300 to change data 

30 8302 is implicitly through the ApplicationMediator 8304 . 
The ApplicationMediator will have a named method to get 
the appropriate field, such as CustomerName as shown. 
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The setData method is called for a ViewEvent 8306 and the 
ViewEvent is fired. The ApplicationMediator 8304 changes 
the data through a property change. The other 
alternative is to change the data explicitly through the 

5 viewController 8300. A put operation on the appropriate 
field is attached to an instance of the data. This is 
sent to the data via a ViewEvent. The operation data. put 
is a property change event. 

In general, the developer should keep the data 

10 "thin." This means the number of classes to represent 
data should be kept small and the size should be kept 
small to facilitate network transfer. For some 
applications, it is appropriate to use lists for "drill 
down" or cached data to facilitate disconnected mode. 

15 

D. TopListener 

With reference now to Figure 84, a flowchart of a 
process used in a TopListener is depicted in accordance 
with a preferred embodiment of the present invention. The 
20 process begins by an ApplicationMediator receiving a 
ViewEvent from a ViewController (step 8400) . A 
determination is made to whether system service is needed 
(step 8402) . If system service is not needed, the process 
terminates. Otherwise, a TopEvent is created with the 
25 proper major codes (step 8404) . Thereafter, the TopEvent 
is fired (step 8406) . After, a set of TopListeners is 
invoked (step 8408) . This set of TopListeners may include 
a single TopListener or many TopListeners. The 
TopListener receives the TopEvent (step 8410) . 
30 Thereafter, a determination is made as to whether the 
major code of the TopEvent is EXIT (step 8412) . 
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If the major code is exit, then the application is 
exited (step 8414) with the process terminating 
thereafter. Otherwise, a determination is made as to 
whether the major code for the TopEvent is MESSAGE (step 
5 8416) . If the major code for the TopEvent is message, 
then the message is displayed for the application (step 
8418) with the process terminating thereafter. 

If the major code is not a message, then a 
determination is made as to whether the major code is a 
10 TITLE (step 8420) . If the major code for the TopEvent is 
a title, then the title is displayed for the application 
(step 8422) with the process terminating thereafter. 
Otherwise, a determination is made as to whether the 
major code for the TopEvent is to execute (EXEC) (step 
15 8424) . If the major code is execute, then the data in 
the TopEvent specifies an application to be launched 
(step 8426) with the process terminating thereafter. If 
none of these major codes are present, the process 
terminates without taking any action. 

20 

E . PI acemen tLi s tener 

With reference now to Figure 85, a flowchart of a 
PlacementListener is depicted in accordance with a 
preferred embodiment of the present invention. The 

25 process begins by the ApplicationMediator receiving a 
ViewEvent from a View Controller (step 8500) . 
Thereafter, a determination is made as to whether 
ViewController needs to be placed (step 8502) . If the 
ViewController does not need to be placed, the process 

30 terminates. Otherwise, a PlacementEvent is created with 
the appropriate major codes (step 8504) . Thereafter, the 
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ApplicationMediator fires the PlacementEvent (step 8506) . 
A set of PlacementListeners is then invoked (step 8508) . 
In the depicted examples, the set of PlacementListeners 
may be a set of one PlacementListener or many 
5 PlacementListeners . 

Thereafter, the PlacementListener receives the 
PlacementEvent (step 8510) . A determination is made as 
to whether the major code for the PlacementEvent is ADD 
(step 8512) . If the PlacementEvent is add, then the 
10 ViewController' s component is added to a visual container 
and ViewController is repainted (step 8514) with the 
process terminating thereafter. With reference to (step 
8512), if the major code is not add, then a determination 
is made as to whether the placement code is removed in 
15 the PlacementEvent (step 8516) . If the PlacementEvent is 
removed, then the ViewController' s component is removed 
from the visual container and repainted (step 8518) with 
the process terminating thereafter. Otherwise, the 
process also terminates. 
20 With reference now to Figures 86-F3, flowcharts 

illustrating processes used in a ViewController are 
depicted in accordance with a preferred embodiment of the 
present invention. Turning first to Figure 86, a 
flowchart illustrating handling of AWTEvents by a 
25 ViewController is depicted in accordance with a preferred 
embodiment of the present invention. The process begins 
by receiving an AWTEvent (step 8600) . The Event is 
handled by manipulating the GUI according to the GUI 
specifications (step 8602) . Then, a determination is 
30 made as to whether the AWTEvent . source is a component to 
validate (step 8603) . If the determination is no, then 
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another determination is made as to whether a ViewEvent 
is needed (step 8604) . if a ViewEvent is needed, then a 
ViewEvent is created (step 8606) . Thereafter, the 
ViewController is disabled (step 8608) and the ViewEvent 
5 is fired (step 8610) with the process then returning. 

With reference again to step 8604, if a ViewEvent is 
not needed, the process .also returns. 

F. ValidationRule 

10 With reference again to step 8602, if the 

AWTEvent . source is a component to validate, the process 
then determines whether the validation level is 
ValidationRule. FOCUS and the AWTEvent is a focus event 
(step 8612) . If the answer to this determination is yes, 

15 then the ValidationRules are applied (step 8614) . A 

determination is made as to whether the application was 
successful (step 8616) . If the application was 
successful, then a determination is made as to whether a 
validation level is equal to ValidationRule . COMPONENT and 

20 whether the AWTEvent is an input event (step 8618) . This 
determination is made directly from step 8612 if the 
validation level is not set equal to 

ValidationRule. FOCUS. The AWTEvent is not a focus event. 
If the determination is that the validation level is a 

25 ValidationRule for a component and the AWTEvent is an 
input event, then the ValidationRules are applied (step 
8620) and a determination is made as to whether the rules 
were successfully applied (step 8622) . 

If the rules were successfully applied, then a 

30 determination is made as to whether the validation level- 
is equal to ValidationRule. VIEWEVENT (step 8624). If 
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this determination is no, the process then returns to 
step 8604 as described above. Otherwise a determination 
is made as to whether a ViewEvent is needed (step 8626) . 
If a ViewEvent is needed, then ValidationRules are 
5 applied (step 8628) . A determination is made as to 
whether the ValidationRules were successfully applied 
(step 8630) . If the ValidationRules were successfully 
applied, the process then proceeds to step 8606 as 
previously described. 

10 In any of the steps in which a determination is made 

as to whether a ValidationRule was successful (steps 
8616, 8622, and 8630), if the application of the rules 
was unsuccessful, then an error message is created (step 
8632) with the process then returning. Steps 8612 and 

15 8618 describe the various times the ViewController will 
validate user input. If the setValidationLevel of a VC is 
set to COMPONENT, then validation is performed on every 
input event for a component (i.e. key strokes, so only 
valid keys are allowed to be inputted) . If the 

20 validationLevel is FOCUS, then validation is performed 
when the user hits the Tab key or uses the mouse to move 
focus out of the current component. If the 
validationLevel is VIEWEVENT, then validation is 
performed when a view event needs to be fired. This 

25 situation typically occurs when the user hits the "Ok" or 
"Next" button for further processing. If a view event is 
not needed in step 8626, the process returns. 

With reference again to step 8618, if the 
determination is such that the validation level is not a 

30 ValidationRule for a component and the AWTEvent is not an 
input event, then the process proceeds to step 8624 as 
described above. 
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With reference now to Figure 87, a flowchart 
illustrating application of ValidationRules is depicted 
in accordance with a preferred embodiment of the present 
invention. Figure 87 is a more detailed description of 
5 steps 8614, 8620, and 8628 in Figure 86. The process is 
applied for each rule defined for the component {step 
8700) . A determination .is made as to whether 
ValidationRules are present that have not been applied 
(step 8702) . If more rules are present, then the 

10 ValidationRule (i) is applied to the component's value 
(step 8704) . A determination is made as to whether a 
successful application has occurred (step 8706) . If a 
successful application has occurred, the process returns 
to step 8700 to select the next rule. 

15 With reference again to step 8706, if the 

application of the rules are unsuccessful, then an 
exception is thrown (step 8708) with the process then 
returning. With reference again to step 8702, if a 
determination that more ValidationRules are not present 

20 for processing, the process also returns. 

G. ViewEvent 

With reference now to Figure 88, a flowchart of a 
process for firing a ViewEvent is depicted in accordance 

25 with a preferred embodiment of the present invention. 
The process begins by selecting a ViewListener (step 
8800) that has not yet been processed from the list of 
ViewListeners that have been added to using 
addViewListener . Thereafter, a determination is made as 

30 to whether ViewListeners are present for processing (step 
8802) . If ViewListeners are present, then invoke the 
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method ViewListener (i) . viewEventPer formed (step 8804} . 
This method is implemented by a ViewListener (such as an 
ApplicationMediator) to process the ViewEvent passed. 
Typically, this processing of the ViewEvent will occur on 
5 a separate thread. Also, the ViewListener may decide to 
"consume" the event by calling the consume () method on 
the ViewEvent. This essentially specifies that the 
ViewEvent should not be sent to any other ViewListeners 
left to be processed. 

10 Thereafter, a determination is made as to whether 

the ViewEvent has been consumed (step 8806) . If the 
ViewEvent is not consumed, the process returns to step 
8800 to select another ViewListener. Otherwise, the 
process returns. With reference again to step 8802, if 

15 more ViewListeners are not present, the process also 
returns . 



20 



H. Data Refresh 

With reference now to Figures 89-98, flowcharts 
illustrating processes used by an ApplicationMediator are 
depicted in accordance with a preferred embodiment of the 
present invention. With reference now to Figure 89, a 
high level flowchart of the process used by the 
ApplicationMediator is depicted in accordance with a 
25 preferred embodiment of the present invention. The 

process begins by creating ViewControllers (step 8900) . 
Thereafter, the ApplicationMediator responds to events 
(step 8902) with the process terminating thereafter. 

With reference now to Figure 90, a flowchart of a 
process for handling DataEvents is depicted in accordance 
with a preferred embodiment of the present invention. 
The process begins by the ApplicationMediator receiving a 
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DataEvent (step 9000) , in response to receiving the 
DataEvent, the ApplicationMediator will send a call to 
refresh data for each ViewController handled by the 
ApplicationMediator (step 9002) with the process 

5 terminating thereafter. 

With reference now to Figure 91 , a flowchart of a 
process for adding a listener is depicted in accordance 
with a preferred embodiment of the present invention. 
The process begins by the ApplicationMediator receiving a 

10 request to add a listener (step 9100) . The listener type 
is then found (step 9102) . The listener is then added to 
a vector (step 9104) with the process terminating 
thereafter . 

With reference now to Figure 92, a flowchart of a 
15 process for removing a listener is depicted in accordance 
with a preferred embodiment of the present invention. 
The process begins by receiving a request to remove a 
listener (step 9200) . The listener type is then found 
(step 9202) . The listener is then removed from the 
20 vector (step 9204) with the process terminating 
thereafter , 

With reference now to Figure 93, a flowchart of a 
process for managing permissions is depicted in 
accordance with a preferred embodiment of the present 
25 invention. The process begins by receiving a request to 
gather and set permissions (step 9300) . The permissions 
are then processed (step 9302) with the process 
terminating thereafter. 

With reference now to Figure 94, a flowchart of a 
30 process for handling ViewEvents is depicted in accordance 
with a preferred embodiment of the present invention. 
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The process begins by receiving a ViewEvent (step 9400) . 
Thereafter, the ViewEvent is processed (step 9402) . A 
determination is made as to whether the major code in the 
ViewEvent is known (step 9404) . If the major code is 
5 known, then a determination is made as to whether the 
minor code is known (step 9406) . If the minor code is 
known, % the process then -handles the specific request 
(step 9408) with the process terminating thereafter. A 
specific request may be, for example, a RequestEvent, a 

10 request for fresh data, a TopEvent, a PlacementEvent, or 
there may not be a specific request* 

With reference again to step 9404, if the major code 
or minor code in step 9406 is unknown, the process 
defaults (step 9410) and terminates thereafter. 

15 With reference now to Figure 95, a flowchart of a 

process for refreshing object data in an 
ApplicationMediator is depicted in accordance with a 
preferred embodiment of the present invention. The 
process begins by receiving an event (step 9500) 

20 (typically a ViewEvent from a ViewController or other 
ApplicationMediator) . A determination is made as to 
whether the processing of the event recieved requires a 
RequestEvent (step 9502) . If a RequestEvent is needed, 
then a RequestEvent is created (step 9504) . Thereafter, 

25 the RequestEvent is fired (step 9506) . The 

ApplicationMediator can repeat the processes of creating 
an event, firing it, processing the results and then go 
on to the next event to create or end. The process then 
returns to step 9502. 

30 With reference again to step 9502, if a RequestEvent 

is not needed for the event, a determination is then made 
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as to whether a TopEvent is needed (step 9510) . If a 
TopEvent is needed, a TopEvent is created (step 9512) and 
the TopEvent is fired (step 9514) . Thereafter, the 
process proceeds to step 9508 as described above. 
5 With reference again to step 9510, if a TopEvent is 

not needed, a determination is then made as to whether a 
PlacementEvent is needed (step 9516) , If a 
PlacementEvent is needed, then a PlacementEvent is 
created (step 9518) . Thereafer, a ViewController is 

10 selected (step 9520) . The PlacementEvent is fired using 
a component from the ViewController (step 9522) with the 
process then proceeding to step 9508. 

With reference again to step 9516, if a 
PlacementEvent is not needed, then a determination is 

15 made as to whether a data refresh is needed (step 9524) . 
If a data refresh is needed, then the data is accessed 
(step 9526) . Thereafter, the refresh method on the 
ViewController or ApplicatiohMediator is called, (step 
9528) with the process then proceeding to step 9508 as 

20 described above. With reference again to step 9524, if a 
data refresh is not needed, then the process terminates. 

With reference now to Figures 96 and 97, diagrams 
illustrating processes used to refresh object data is 
depicted in accordance with a preferred embodiment of the 

25 present invention. The data coming in can be one object 
or an object containing multiple objects, such as a 
Vector or more generically, a list. This data is 
represented by the type "Object data;" the process of 
data refresh includes seeing if the data is a singleton 

30 and if data is handled (a recognized type) , then format " 
it (cast) into the recognized type and then call refresh 
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again in the same view controller. For example, 
refresh (Object data) yields refresh (Customer data) if 
this data type is handled (a recognized aggregate type 
such as Vector), then the data is formatted (cast) into 
5 the recognized type. Then refresh is called again in the 
same view controller. For example, refresh (Object 
dataAggreate) yields refresh (Vector data). 

If the data is an aggregate (not a singleton) , and 
if the data is not handled, then iterations are performed 

10 over the aggregate and refresh is called for each object 
in the aggregate. For example, refresh (Ob j ect 
dataNotSupportedAggregate) yields refresh (Object 
dataNotSupportedAggregate (i) ) for each i. 

When a singleton data type is supported, has been 

15 cast, and a new refresh has been called, there are a 
plurality of actions that can result. These actions 
include, for example: updating one or more components, 
containers or beans; updating the reference to the local 
data model; application of ValidationRules again; and 

20 even the firing of a new ViewEvent. Thus, for each 

refresh in the plurality of refreshes possible from the 
initial refresh, a plurality of actions can result from 
the plurality of possible actions. 

With reference now to Figure 96, a flowchart of a 

25 process for refreshing data in an ApplicationMediator is 
depicted in accordance with the preferred embodiment of 
the present invention. The process begins by receiving a 
call to refresh object data (step 9600) . Thereafter, an 
access of data is performed (step 9602) . Data is 

30 accessed by the ApplicationMediator rarely. The reasons 
to access data in an ApplicationMediator arise around the 
need to activate another sub ApplicationMediator or a 
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ViewController. Thereafter, ApplicationMediator is 
selected for processing (step 9604) . This step is used 
to identify unprocessed ApplicationMediators for 
processing. Thereafter, an 

5 ApplicationMediator (i) • refresh (Object data) is performed 
(step 9606) . Thereafter, a determination is made as to 
whether more ApplicationMediators are present for 
processing (step 9608) . If more ApplicationMediators are 
present, the process returns to step 9604. Otherwise, a 

10 ViewController is identified for processing (step 9610) . 
This step is used to select unprocessed ViewControllers 
for processing. A ViewController (i) . refresh (Obj ect 
data) is performed (step 9612) . This step is described 
in more detail in Figure 97 below. Thereafter, a 

15 determination is made as to whether more ViewControllers 
are present for processing (step 9614) . If additional 
ViewContollers are present, the process returns to step 
9610. Otherwise, the process returns. 

With reference now to Figure 97, a flowchart of a 

20 ViewContoller refresh process is depicted in accordance 
with the preferred embodiment of the present invention. 
Figure 97 is a more detailed description of step 9612 in 
Figure 96. The process begins by receiving a request to 
refresh (Object data) (step 9700) . Thereafter, a 

25 determination is made as to whether the data is a 

singleton (step 9702) . If the data is not a singleton, 
then a determination is made as to whether the data is 
handled as an aggregate (step 9704) . If the data is to 
be handled -as an aggregate, then a determination is made 

30 as to whether additional objects are present in the 
aggregate that are unprocessed (step 9706) ^ . If 
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additional objects are present, then the use object 
process is performed (step 9708) . By using an object, an 
unprocessed object is selected with a recursive call of 
refresh on that object. Once that object (and all of its 
5 objects) are processed, the next object is then selected. 
Thereafter, the process returns to step 9706. When no 
more objects are present;, the process returns. 

With reference again to step 9704, if the data is 
not to be handled as an aggregate, the process then 

10 proceeds to step 9712 as described below. 

With reference again to step 9702, if the data is a 
singleton, a determination is made as to whether the data 
is an instance of a recognized type T (step 9710) . Type 
"T" is any Java data model type that the JTC systems is 

15 currently supporting. For example, you may support a 
type Object data; and a type KeyValue data; Until you 
then add support for XMLData data, T cannot be of that 
type. Once the code is added for XMLData type, T can be 
of that type. If the data is an instance of a recognized 

20 type T, then the data is cast into a recognized type T 
(step 9712) . Thereafter, a call refresh for type T is 
made (step 9714) . This call may be, for example, refresh 
(T data) . Thereafter, the local state is updated (step 
9716) , and the GUI is updated (step 9718) with the 

25 process then returning. With reference again to step 

9710, if the data is not an instance of a recognized type 
then an ignore or error is generated (step 9720) with the 
process then returning. 

With reference now to Figure 98, a flowchart of a 

30 process used to process RequestEvents is depicted in 
accordance with a preferred embodiment of the present 
invention. The -process begins by the firing of a 
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RequestEvent (step 9800) . Thereafter, the process will 
select a RequestListener (step 9802) . A determination is 
made as to whether more RequestListeners are present for 
processing (step 9804) . If a RequestListener is present, 
5 then the process executes 

RequestListener (i) . requestEventPer formed (step 9806) . 
Thereafter, a determination is made as to whether the 
RequestEvent has been consumed (step 9808) . If the 
RequestEvent has not been consumed, the process returns 

10 to step 9802 to select another RequestListener for 
processing. Otherwise, the process returns. With 
reference again to step 9804, if additional 
RequestListeners are not present for processing, all of 
the RequestListeners have been processed and the process 

15 returns. 

I* Hierarchical ApplicationMediators 

The present invention provides for the use of 
hierarchical ApplicationMediators for handling events 
from ViewControllers. In such a system, 

20 ApplicationMediators are arranged in a hierarchical 
fashion in which different ApplicationMediators may 
handle different types of events or perform different 
functions. If graphed, the ApplicationMediators would 
look like the tree in which nodes represent 

25 ApplicationMediators. Events would be received by the 
lowest level ApplicationMediators, those farthest away 
from the root. One event will percolate up the graph and 
then the event might cause actions to a group of 
ApplicationMediators from the set of ApplicationMediators 

30 which in turn may results in a set of actions from the 
plurality of view controllers. Another way to view it, 
"event" moves up the graph and then come back down -in 
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numerous possible paths. 

Each node in the graph is an ApplicationMediator . 
View controllers. The partitioning of the nodes are 
based on some logical heuristic. On example is the 
5 higher the node, the higher semantic level the code has. 

With reference now to Figure 99, a flowchart of an 
initialization process for creating hierarchical 
ApplicationMediators is depicted in accordance with a 
preferred embodiment of the present invention. The 

10 process begins by creating a Top ApplicationMediator 
(step 9900). TopListeners are added {step 9902), and 
RequestListeners are added (step 9904) . Thereafter, 
PlacementListeners are added (step 9906) and 
ViewListeners are added (step 9908) . 

15 The concept here is that when the application starts 

the top level AM is provided with the highest level 
listeners. Then, any Ams created as children AMs are 
initialized with the same listeners as specified by the 
top level AM. Once the Listeners are created they will 

20 wait to be called back via a fireEvent 

invocation . . . topEventPer formed ( ) , viewEventPerf ormed ( ) , 
requestEventPer formed ( ) , placementEventPerf ormed ( ) etc 

Next, a second level ApplicationMediator is created 
(step 9910), and the TopListeners are cloned (step 9912). 

25 The RequestListeners are cloned (step 9914), and the 
PlacementListeners are cloned (step 9916) . 

Cloning means to create an exact copy, which means 
that the copy has its own specific reference while a 
non-cloned copy would have the same reference as the 

30 original, which means that if a person has a dollar 

amount and choose to copy the amount into another object 
without cloning it then any changes made to the copy will 
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also affect the original, while the original is cloned 
rather than just copied, any changes to the cloned object 
will only affect the clone. Therefore, the reason to 
clone the listeners here is so that children 

5 ApplicationMediators do not have the same Vector instance 
as the parent ApplicationMediators. If the Vector 
instance was the same, then the children 
ApplicationMediators and top level ApplicationMediator 
would always share the same lists of listeners. 

10 Thereafter, the top ApplicationMediator is added as 

a ViewListener to the second level ApplicationMediator 
(step 9918) . A determination is then made as to whether 
a ViewController is to be added (step 9920) . If a 
ViewController is not to be added, then a determination 

15 is made as to whether additional second level 

ApplicationMediators are to be added (step 9922) . If 
additional second level ApplicationMediators are to be 
added, the process then returns to step 9910. Otherwise, 
a determination as to whether a lower level 

20 ApplicationMediator is to be added (step 9924) . 

If a lower level ApplicationMediator is to be added, 
then the lower level ApplicationMediator is created (step 
9926) . The TopListeners are cloned (step 9928) and the 
RequestListeners are cloned (step 9930) . Thereafter, the 

25 PlacementListeners are cloned (step 9932) . Then, the 
upper level ApplicationMediator is added as the 
ViewListener (step 9934) , The upper level 
ApplicationMediator is the ApplicationMediator in the 
level above the one created. 

30 If there are no more lower level 

ApplicationMediators then the initialization process 
completes and application is ready to begin. Also, lower 
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level ApplicaitonMediators and ViewControllers may be 
created at any time while the application is running. 

Thereafter, the process returns to step 9920. With 
reference to step 9920, if a ViewController is to be 
5 added, then the ViewController is created (step 9936) . 
Then, the parent level ApplicationMediator is added as 
the ViewListener (step 9938) with the process then 
proceeding to step 9922. 

A parent level ApplicationMediator is the 

10 application mediator that manages several 

ApplicationMediators and/or ViewControllers. The usage 
for this is when functions of an application are nested. 
For example, assume an application has a function to 
display an interest rate calculator. This calculator has 

15 maybe several screens associated with it. Therefore, an 
CalculatorApplicationMediator is created to manage those 
screens. Now, assume that this calculator function will 
be used by two different higher-level processes such as a 
Auto Loan calculator and a Home Mortgage calculator. So 

20 the AutoLoanAM and HomeMortgageAM would be parent AMs for 
the CalculatorAM. The parent/child APPLICATIONMEDIATOR 
communication is done through ViewEvents and refresh just 
like APPLICATIONMEDIATOR to VIEWCONTROLLER communication. 
In other words, a child ApplicationMediator represents a 

25 child or sub-process that can be re-used in many places. 

With reference now to Figure 100, a flowchart of a 
process for handling events in a hierarchical 
ApplicationMediator system is depicted in accordance with 
a preferred embodiment of the present invention. The 

30 process begins by receiving user action input (step 
10000) . A ComponentEvent is created and fired (step 
10002) . The ViewController receives the ComponentEvent 



129 * 

Docket No. AT9-99-339 

(step 10004) . A determination is then made as to whether 
the ComponentEvent is a ViewEvent (step 10006) . If the 
ComponentEvent is not a ViewEvent, the process returns to 
step 10000. Otherwise, the ViewController creates and 
5 fires a ViewEvent (step 10008), The ViewController' s 
parent ApplicationMediator receives the ViewEvent (step 
10010) . 

A determination is made as to whether the 
ApplicationMediator is able to handle the ViewEvent (step 

10 10012) . If the ApplicationMediator is able to handle the 
ViewEvent, the ViewEvent is processed (step 10014) . 
Thereafter, a determination is made as to whether the 
processing has completed (step 10016) . If the processing 
has completed, the process returns to step 10000. 

15 Otherwise, the ViewEvent is refired (step 10018) . The 
parent ApplicationMediator to the current 
ApplicationMediator receives the ViewEvent (step 10020) 
with the process then returning to step 10012. 

With reference again to step 10012, if the 

20 ApplicationMediator is not able to handle the ViewEvent, 
the process proceeds directly to step 10018 as described 
above . 

J. Virtual Application Mediators 
With reference now to Figures 101-104, flowcharts 
25 illustrating state encoding in an ApplicationMediator is 
depicted in accordance with a preferred embodiment of the 
present invention. An ApplicationMediator can be built 
as a state machine loaded by properties file, which 
describes other ApplicationMediators . These other 
30 AppliationMediators are also referred to as Virtual 

ApplicationMediators. The present invention employs an 
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encoding language to describe the state transitions of an 
ApplicationMediator. Encoding is provided for 
ViewEvents, refresh of data, SettingProperties, 
SettingPermissions, and for methods that may alter the 
5 ApplicationMediator state. The actual Virtual 

ApplicationMediator used may be described in and passed 
in SetProperties . 

An AWTEvent is generalized with increased semantics 
first as a ViewEvent, then as a RequestEvent, 

10 PlacementEvent and TopEvent. 

Numerous heuristics may be employed that can 
determine how to solve mediation, such as how to encode a 
RequestEvent, why a RequestEvent and not a TopEvent or 
ViewController action. 

15 More than one semantic event can be generated for 

each ViewEvent. 

The Application Mediator interface provides default 
behavior to manage ViewControllers, ApplicationMediators, 
and to add/fire/remove PlacementListeners, ViewListeners, 

20 and a TopListener. The ApplicationMediatorlmpl 

implements methods in the ApplicationMediator and JTC 
interfaces * 

A dispatching state machine is used to manage all of 
these actions. As indicated by the name, a state machine 

25 consists of a finite set of states, a set of possible 

transitions between states, and, optionally, one or more 
actions to be performed when a transition is made between 
two states. State recognition will be based on the 
object being monitored. For example, for a ViewEvent the 

30 state is typically determined by a subset of the source 

of the event, the major code, the minor code and possibly 
the value of the data reference. Examples of possible 
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actions are to make an existing ViewController visible, 
to create/fire a PlacementEvent, to create/fire a 
RequestEvent, or to create/fire a TopEvent. It is be 
possible to "hand build" the finite state machine for 
5 every ApplicationMediator, but this route is very 
tedious . 

Instead, according to the present invention, the 
virtual ApplicationMediator builds the finite state 
machine from a set of transition rules that recognize the 

10 current state and if matched, trigger a state transition 
and associated actions. In general, it is unpractical to 
build a language within a language. If the encoding of 
the transition rules included control statements (i.e. 
if/then/else, while, switch) it is better to implement 

15 the ApplicationMediator in the programming language at 
hand, Java. If the definition of the transition rules 
are indeed simple, not control structures and the 
ApplicationMediator has little state except the Vectors 
of its ApplicationMediators, ViewControllers, Properties, 

20 Permissions, and Resources, then encoding becomes simple, 
flexible, powerful and easy to manage. The resulting 
benefit is that one set of ApplicationMediator code can 
be used to implement numerous virtual 

ApplicationMediators simply by changing the transition 

25 rules via the setProperties method. 

In Figure 101, a flowchart for a process for 
building a state machine is depicted in accordance with a 
preferred embodiment of the present invention. The 
process begins by loading a configuration file of 

30 ApplicationMediators state stanzas (step 10100) . A 

multi-dimensional list of the configuration file is built 
(step 10102) ♦ A multi-dimensional list has more than' one 
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dimension, traditional list are a single dimension 
implementation such as a list of numbers, or collection 
of elements . Multi-dimensional list would have, as its 
elements, containers that also represent containers. For 
5 example, a list of lists. This is clearly a list, yet the 
elements themselves are lists. This means a particular 
list in one dimension may be referenced while accessing 
the elements of that list in another dimension. Example 
colorList is a list of colors. To reference a color, a 

10 call would be made, such as colorList [2] and the color 

that is stored at location 2 would be obtained. If it is 
desired to store several list of list of colors and 
access to a particliar color that is in color list 2, at 
location 4 is desired, the color would be referenced as 

15 listOfColors [2] [4] . Thereafter, the state machine 

processes events and calls (step 10104) with the process 
terminating thereafter. 

Turning now to Figure 102, example table entries 
from the loading of a configuration file for a virtual 

20 ApplicationMediator is depicted in accordance with a 
preferred embodiment of the present invention. 

With reference now to Figures 103 and 104, an access 
state machine used to determine whether processing of a 
ViewEvent is needed is depicted in accordance with a 

25 preferred embodiment of the present invention. The 
process begins by receiving a ViewEvent (step 10300) . 
After the ViewEvent . source is located (step 10302), a 
determination is then made as to whether the source is in 
a virtual ApplicationMediator list. (step 10304) . If 

30 the ViewController is not located in the dispatch table, 
the process returns. Otherwise, a determination is made 
as to whether a minor code has been set for the ViewEvent 
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(step 10306) . If a minor code has been set for the 
ViewEvent, then the table entries locate source 
/ViewEvent .ma jor/ViewEvent. minor tuple (step 10308) . 
The process then determines whether more table 
5 entries are present for processing (step 10310) . If more 
table entries are not present for processing, the process 
returns. Otherwise, table entry (i) is used (step 
10312) . A determination is made as to whether table 
entry (i) has a major equal to ViewEvent .major and/or 

10 entry (i) .minor is equal to ViewEvent .minor (step 10314). 
If the table does not have a major equal to the major for 
the ViewEvent, the process returns to step 10310 to see 
if more table entries are present for processing. 
Otherwise, a determination is made as to whether more 

15 action entries are present for entry(i) (step 10316). If 
additional action entries are not present, the process 
also returns to step 10310. 

With reference again to step 10306, if the ViewEvent 
is not a minor code set, then the table entries matching 

20 source and the major pair for the ViewEvent are located 
(step 10318) with the process then returning to step 
10310. 

With reference again to step 10316, if more action 
entries are present for entry (i) , the process then 

25 proceeds to Figure 104 and determines whether action (i) 
is equal to RE (step 10320). If action (i) equals RE, 
then a RequestEvent is created with action (i) .major, 
action (i) .minor, ViewEvent .data (step 10322). 
Thereafter, the RequestEvent is fired (step 10324) with 

30 the process then returning. With reference again to step 
10320, if action (i) does not equal to RE, then a 
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determination is made as to whether action (i) equals TE 
(step 10326). If action (i) equals TE, then a TopEvent is 
created with an action (i) major and an action (i) minor 
(step 10328) . Thereafter, the TopEvent is fired (step 
5 10330) with the process then returning. 

With reference again to step 10326, if action (i) 
does not equal TE, then. a determination is made as to 
whether action (i) is equal to PE (step 10332) . If 
action (i) is equal to PE, then a PlacementEvent is 

10 created with an action (i) major and an action (i) minor 
along with a ViewEvent source (step 10334) . Thereafter, 
the PlacementEvent is fired (step 10336) with the process 
returning. With reference again to step 10332, if 
action (i) does not equal to PE, then determination is 

15 made as to whether action (i) is equal to VIEWCONTROLLER 
(step 10338). If action(i) is equal is VIEWCONTROLLER, 
then a refresh data is performed on the source for the 
ViewEvent (step 10340) with process then returning. With 
reference again to step 10338, if action (i) does not 

20 equal ViewController, then an error has occurred and an 
error is generated (step 10342) with the process then 
returning 

K. Serialization/Deserialization 

When communications take place between the client and 
25 the server, it is convenient to "pack" an object into a 

single entity, send it over the network, and then "unpack" 
it at the other end. The Serialize packs the object for 
transmission and the Deserializer unpacks it at the other 
end. 

30 With reference now to Figure 105, a diagram of a 

serializer system is depicted in accordance with a 
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preferred embodiment of the present invention. 
Serializer system 10500 is used to serialize data for 
transfer. With reference to Figure 106, a deserialier is 
depicted in accordance with a preferred embodiment of the 
5 present invention. 

When an object is serialized, the object is being 
written to an external source. The size of the data 
array is first written and then the data is sent to a 
serializer for serialization. Typically, a serializer 

10 will look up the code for the data element, write the 
code to the stream, and then look up the serializer for 
the element. If the serializer for the element exists, 
then the serializer is allowed to write the element. 
Otherwise, if the element is "externalizable", it is 

15 allowed to write itself. In this last case, it is a call 
to the method writeExternal on the data element. If the 
element does not have a serializer and is not 
externalizable, then it is written as a standard object. 
Such a writing of the element as a standard object is 

20 expensive in terms of serialization space and time and 
should not happen under normal circumstance. 

When an object is read, the size of the data array 
is read. Thereafter, a base serializer class is used to 
read each data element. The code for the data element is 

25 read and looked up to see if a serializer exists for the 
code. If a serializer exists, then the serializer reads 
the data elements and creates the object. Otherwise, an 
instance of the element type is created. If the element 
is externalizable, the element is allowed to read itself. 

30 This may be accomplished through a call to readExternal 
on the data element. Otherwise, the data element is read 
into an object. 
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The default serialization provided by Java writes 
the class name of the data element then the attribute 
name and the value for each attribute of the data 
element. The size benefit provided by the present 
5 invention comes from writing a code representing the 

element type instead of the type name and the attributes 
that are required to recreate the data objects without 
writing the names of the attributes. For example, an 
integer is written as follows: The class name 

10 [java.lang. Inter] , the attribute name [value 

java. lang. Number ] , the attribute value [00 00 00 08] 
size: 81 bytes. Alternatively enhanced serialization: the 
code [01], the value [00 00 00 08] size: 11 bytes. 
With reference now to Figure 107, a diagram 

15 illustrating an object array is depicted in accordance 
with a preferred embodiment of the present invention. 
Typically user defined data classes extend a class 
similar to that shown in Figure 107. Specifically, 
Figure 107 illustrates an object array that contains all 

20 the attributes of the user-defined data. The subclasses 
just provide getter/setter methods (i.e. getXXXO and 
setXXXO methods where XXX is a particular attribute 
name) . These getter and setter methods just access the 
object array in Figure 107 using getData and setData 

25 methods based on an index for the attribute. This is a 
common extension of using an indexed-array data model 
combined with an attribute-based object model. The 
advantage of this model is to reduce the serialization 
size by removing the attribute names that are typically 

30 outputted in the default Java serialization mechanism. 

Turning now to Figure 108, a diagram illustrating 
code used in a serialization method is depicted in 
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accordance with a preferred embodiment of the present 
invention. The mechanism of the present invention adds 
to the serialization method 10800 provided in Figure 108. 
To use the special serialization, any and all 
user-defined data classes can extend the BaseDataS class 
10800 illustrated in Figure 108. In Java, the default 
Java serialization for an object can be overridden by 
implementing the Externalizable interface illustrated in 
Figure 109 and implementing the methods readExternal and 
writeExternal for reading/writing from/to input/output 
stream. 

Method 10800 uses the BaseSerializer class, as 
illustrated in Figure 110 for implementing default 
serialization for many of Java's base classes and even 
some of Java's collection classes. Also, the user can 
specify a serializer for other data classes by 
implementing the SerializerIF interface 10900 in Figure 
109 and listing the serializer T s class name on the same 
line after the data class name in the ClassNames.ini file 
separated by a space. If no serializer is specified and 
none are provided by the BaseSerializer 11000, then the 
default Java serialization method for that class is used. 

Using this new serialization mechanism coded in the 
read/write External methods of BaseDataS method in Figure 
25 108 and BaseSerializer method 10800 in Figure 109 

provides the benefits of reduced serialization size. The 
combination of the two mechanisms above provide the 8 0% 
reduction in serialization size. 

In these examples, the serialization process of the 
present invention is able to reduce the serialization 
size further by completely removing any full-path class 
name strings that are typically outputted in the default 
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Java serialization. Of course, depending on the 
implementation, other information may be removed and 
processed a similar manner to the full-path class name 
strings , 

5 The number and length of these class name strings 

can be incur a high amount of overhead for serialization. 
The only disadvantage is that the actual class names must 
be provided on both sides of serialization 
(reader/writer) . The class names are hashed and the hash 
10 code is stored in the serialization instead of the actual 
full class name. (This is why the classes need to be 
listed in the ClassNames.ini file and provided on either 
side of the client/server that needs 

serialize/unserialize the data) . Another way to reduce 
15 this dependency is to automatically send the class names 
once before any other communication between client/server 
is done. 

The ClassNames.ini file contains a sequence of lines 
that are either a class name for a user-defined data class 

20 or a class name followed by a serializer' s class name if 
the user created their own serializer for that particular 
data class. If no serializer is provided and the data 
class is not in the BaseSerializer, then the default Java 
serializer for the data class is used. The process of 

25 reading this file produces a table that contains the class 
name, a hash code, and a serializer. The flowchart in 
Figure 111 shows how the ClassNames.ini file is read. 

Since the read will be buffered, an empty 
BufferedRead object is declared (step 11102) . A 

30 FileReader object is created and passed to the constructor 
for the BufferedRead object (step 11104) . Each line of " 
the file is read sequentially (step 11106) . A 
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determination is then made as to whether there is 
additional data in the file (step 11108) . If so, control 
passes to the finalization code (step 11130) . Otherwise, 
the line is trimmed (step 11110), which means all leading 
5 and trailing spaces are removed. Next, a determination is 
made as to whether the line length is 0 or it begins with 
a # (indicating a comment) (step 11112) . If not, the 
process returns to step 11106 where another line is read. 
For lines with data, a string tokenizer is created and the 

10 first token is read (this is the class name) and the Java 
method hashcodeO is applied to the class name to find an 
associated integer value (step 11114) ; this integer value 
is used for hash table processing. StringTokenizer is a 
built-in Java class that breaks a string into its 

15 components, much like a sentence could be broken into 

separate words. Next, an empty serializer is created (step 
11116) . 

A determination is then made as to whether there is 
another token (step 11118) . If so, then it is fetched 

20 (this is a user-defined serializer name) (step 11120) and 
a serializer is created using this name (step 11122) . If 
this causes an exception, it is ignored (step 11124) and 
the class name, hash code, and serializer name are added 
to the table (step 11126) . Control returns to step 11106 

25 to read the next line from the file. If an exception 
occurs at any time while processing the ini file, it is 
ignored (step 11128) . The finalization code closes the 
file (step 11130); any exception is ignored (step 11132). 
Then the table is written (step 11134) completing the 

30 process of reading the ini file. With reference again to - 
step 11122, if there are no additional tokens in the 
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tokenizer, the process proceeds directly to step 11126 as 
described above. 

L. Permissions 

A permission is a capability that a user is allowed 
5 to perform. For example, given a user (defined with a 
user id, password, location, etc.), this user's 
capabilities may include running ApplicationMediator 1 
and 2, but not 3. Similarly, the same user may be 
allowed to operate ViewController 1 and 2 in 
10 ApplicationMediator 1, but not ViewController 3. 

Similarly, the same user may be allowed to use all of the 
GUI components in ViewController 1 in ApplicationMediator 
1, except the "next" button, which is disabled. 
A permission is the encoding of the above 
15 functionality. It is defined as part of the enterprise 
deployment business processes and security model. 
.Enterprise support to maintain storage of permission data 
is required for JTC permissions to operate. 

For example, using the above description, [Joshua: 
20 "AMl=yes AM2=yes AM3=no"] would be defined before 

deployment and stored in a database and later to be sent 
to the client. The client program knows that, while the 
current user is Joshua, AM3 cannot be started. 

For another example, [Jacob: "AMI: VCl=yes VC2=yes 
25 VC3=no ,T ] would be defined before deployment and stored in 
a database and later to be sent to the client. Now the 
client program knows that, while the current user is 
Jacob and running AMI, Jacob cannot use VC3 . 

For example, [John: "AMI .VC1 : customerlist=yes 
30 o'k=yes previous=yes namef iled=yes next=no"] would be 

defined before deployment and stored in a database and to 
be sent to the client. Now the client program knows 
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that, while the current user is John and running AMI, and 
in VC1, the customerlist, ok button, previous button, and 
namefield are enabled while the next button is disabled. 
The JTC ApplicationMediators and ViewControllers alter 
5 their internal state when setPermissions method is 
called. They do not hard code user permission 
information. They do check a system specific user session 
and compare it to their permission state to determine 
what actions to alter for ViewEvents, PlacementEvents, 
10 etc. 

Likewise, possibly at build time, the 
ApplicationMediators and ViewControllers, when called 
with getPermissions, will return the sets of "keys" that 
they will react to at runtime. The actual value of the 

15 keys (for example, "yes" above) is implementation and 
business specific. 

With respect to permissions, user will typically 
login to an Application. Login validation is typically 
provided by external services. The user may have a role 

20 based on various attributes, such as user ID, password, 
location, or time. After logging in, the user will 
execute the Application as defined by the role. 
Sometimes, functions provided by another role not 
accessible by the current user may be required. For 

25 example, a cashier may need to void a transaction, 

requiring the manager to issue an override. For another 
example, a salesperson may need a branch banking loan 
officer to approve a loan. In such a case, a new user 
will login to supplement or replace the current user. 

30 The new user can execute the Application according to the 
new role. In such a case, more functionality may be 
enabled. Thereafter, the new user will logout. The 
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architectural pattern of the present invention provides a 
key/ value pair of permissions model to support such 
roles. In such a case, ApplicationMediators may enable 
and disable ViewControllers while ViewControllers enable 
5 and disable GUI parts. In such a case, an 

ApplicationMediator will return a list of "keys" that 
represent alterable items. These are usually 
ViewControllers. New ViewControllers will return a list 
of "keys" that represent alterable items. These are 

10 usually GUI related components, containers and beans. A 
user management system may create a GUI tool to map role 
definitions to the ApplicationMediator and ViewController 
permission keys (i.e. IBM's On Demand Server). In such a 
case, for example, for each key, a well defined value is 

15 stored that defines the alterable item. These keys/value 
mapping are stored in a database. In setting 
permissions, if a login is successful, the login and 
service provider will provide the key/ value mappings . 
For example, ApplicationMediators will be passed the 

20 key/value mappings. In turn, the ApplicationMediators 

will pass them to the ViewControllers associated with the 
ApplicationMediators . 

The persmission information is almost always 
retrieved or changed via a change in user login 

25 (security) . A JTC application may choose to create a 

simple list of the user login sessions. Each session may 
contain permissions for the user as well as properties, 
references to ApplicationMediators and references to 
ViewControllers. A policy of a single current user, two 

30 current users or multiple current users may be 

implemented. in all cases, the ApplicationMediators and 
ViewControllers do not know why properties are being set, 
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they are just set because top level ApplicationMediator 
receives the properties data from the server or the login 
session list and calls the setPermissions method. 
Figures 112-119 are a series of flowcharts 
5 describing the process for getting and setting 

permissions are depicted in accordance with a preferred 
embodiment of the present invention. With reference now 
to Figure 112, a high level flowchart of a process for 
obtaining permissions is depicted in accordance with a 

10 preferred embodiment of the present invention. The 

process begins by determining whether a user profile has 
been created (step 11200) . If a user profile has not 
been created, the process creates a user profile (step 
11202). Thereafter, the process returns to step 11200. 

15 If a user profile has been created, then program 

permissions are obtained (step 11204) . These program 
permissions are stored as permission keys in a database 
(step 11206) with the process terminating thereafter. 

With reference now to Figure 113, a flowchart of a 

20 process for getting program permissions is depicted in 
accordance with a preferred embodiment of the present 
invention. The process is iterated for each 
ApplicationMediator created (step 11300) . A 
determination is made as to whether more 

25 ApplicationMediators are present (step 11302) . If more 
ApplicationMediators are present that have not been 
processed, then the permission keys for the particular 
ApplicationMediator are added to the list (step 11304) 
with the process then returning to step 11302. With 

30 reference again to step 11302, if more 

ApplicationMediators are not present for processing, then 
a list of keys are returned (step 11306) with the process 



144 

Docket No. AT9-99-339 

terminating thereafter. 

With reference now to Figure 114, a flowchart of a 
process for obtaining ApplicationMediator permissions is 
depicted in accordance with a preferred embodiment of the 
5 present invention. The process begins by iterating for 
each ViewController created (step 11400) . A 
determination is then made as to whether more 
ViewControllers are present for processing (step 11402) . 
If more ViewControllers are present, then the permission 
10 keys for the ViewController are obtained and added to the 
list (step 11404) with the process then returning to step 
11400. 

With reference to step 11402, if more 
ViewControllers are not present for processing, then the 

15 names of the ViewControllers are added to the list formed 
for each ViewController (step 11406) . Next, a list of 
keys are returned (step 11408) with the process 
terminating thereafter. 

With reference now to Figure 115, a flowchart of a 

20 process for obtaining ViewController permissions is 

depicted in accordance with a preferred embodiment of the 
present invention. The process begins by iterating for 
each component, container or bean created (step 11500) . 
A determination is made as whether more components are 

25 present for processing (step 11502) . If more components 
are present, a determination is then made as to whether 
the component is alterable at run time based on 
permissions (step 11504) . If the component is not 
alterable at run time, then the process returns to step 

30 11502 to process another component. Otherwise, a key 
1 representing the component is created (step 11506) . The 
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key is then added to the list (step 11508) with the 
process then returning to step 11500. With reference to 
step 11502, if more components are not present, then a 
list of keys are returned to step 11510 with the process 
5 terminating thereafter. 

With reference now to Figure 116, a flowchart of a 
process for setting permissions is depicted in accordance 
with a preferred embodiment of the present invention. 
The process begins by determining whether the user is 

10 logged in (step 11600) . If the user is not logged in, 
then a login process is performed (step 11602) with the 
process then returning to step 11600. 

When the user is logged in, program permissions are 
obtained from the database (step 11604) . Thereafter, the 

15 program permissions are set (step 11606) with the process 
then terminating. 

With reference now to Figure 117, a flowchart of a 
process for setting program permissions is depicted in 
accordance with a preferred embodiment of the present 

20 invention. The process begins with iterating through 
each ApplicationMediator present and selects an 
ApplicationMediator for processing (step 11700} . A 
determination is then made as to whether more 
ApplicationMediators are present (step 11702) . If more 

25 ApplicationMediators are not present, the process then 
returns. Otherwise, permission keys are set for the 
particular ApplicationMediator being processed (step 
11704) with the process then returning to step 11700. 

With reference now to Figure 118, a flowchart of a 

30 process for setting ApplicationMediator permissions is - 
depicted in accordance with a preferred embodiment of the 
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present invention. The process begins by selecting a 
ViewController for processing and will iterate through 
each ViewController present (step 11800). Thereafter, a 
determination is made as to whether more ViewControllers 
5 are present (step 11802) . If more ViewControllers are 
present for processing, the process then sets permission 
keys for the particular .ViewController (step 11804) with 
the process then returning to step 11800. With reference 
back to step 11802, when additional View Controllers are 

10 not present for processing, then for each 

ApplicationMediator permission key, the value is 
remembered and applied to the ViewController at one time 
(step 11806) with the process returning thereafter. 
With reference to Figure 119, a flowchart of a 

15 process for setting ViewController permissions is 

depicted in accordance with a preferred embodiment of the 
present invention. The process begins by selecting a 
permission key for processing and will iterate for each 
permission key (step 11900) . A determination is then 

20 made as to whether more permission keys are present (step 
11902) . If more permission keys are present, the process 
then gets the value for the key (step 11904) . 
Thereafter, a value is applied to the particular 
components (step 11906) . The value may be, for example, 

25 related to the method setVisible, setEnabled, or 

setAttribute. The process then returns to step 11900. 
With reference to step 11902, if more keys are not 
present, the process then returns. 



30 VIII. Example Patterns 

Figures 120-123 illustrate example patterns using 
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the architectural pattern of the present invention. 
Turning now to Figure 120, a sample pattern for a Uniform 
resource locator (URL) mapper 12000 is depicted in 
accordance with a preferred embodiment of the present 
5 invention. URL mapper 12000 is a pattern which provides 
a mapping to URL links that are cached. The user 
interface 12002 is part of the ViewController . User 
interactions that are AWT events are translated to 
ViewEvents that are processed by the ApplicationMediator 

10 12004. These ViewEvents become RequestEvents that are 
sent via the transporter 12006 to the destination 12008. 
The RequestEvent responses carry the hypertext markup 
language (HTML) and are cached. 

With reference now to Figure 121, a data model using 

15 the architectural pattern of the present invention is 

depicted in accordance with a preferred embodiment of the 
present invention. In this example, pattern 12100 in 
Figure 121 illustrates the use of data models. The user 
interface 12102 is implemented as multiple classes that 

20 can interact with an XML database 12104. ViewEvents 

generated as a result of user interaction are translated 
into RequestEvents by the ApplicationMediator 12106. 
These RequestEvents are sent to the destination 12110 via 
the transported 12108. The RequestEvent responses carry 

25 XML objects that are put into the XML database. 

Turning next to Figure 122, a diagram illustrating 
interaction with logged data objects processed in a 
streaming environment is depicted in accordance with a 
preferred embodiment of the present invention. In this 

30 example, the pattern 12200 in Figure 122 illustrates 
interaction with live data objects processed in a 
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streaming environment. The user interface 12202 is 
implemented as multiple classes that can interact with a 
Customer database 12204, There is also asynchronous 
interaction with CurrencyCounter 12206 that keeps track 
5 of the data objects. ViewEvents generated as a result of 
user interaction are translated into RequestEvents by the 
ApplicationMediator 122Q8. These RequestEvents are sent 
to the destination 12212 via the transported 12210. This 
is an Enterprise Java Beans application where EJB objects 

10 are sent back as part of the responses. These objects 
affect both the Customer database 12204 and the 
CurrencyCounter 12206. The Customer data 12204 can also 
be accessed remotely through an Remote Method Invocation 
(RMI) server 12214. The CurrencyCounter 12206 also 

15 communicates asynchronously with an RS232 port 12216. 

A JTC program and its elements (i.e. Transporters, 
Destinations, ApplicationMediators, ViewControllers, 
components/containers, beans and the main program) all 
implement the JTC interface. If a reference to the main 

20 program is available, a call may be made to getJTCs and a 
list of all the objects that main allocates that 
implement the JTC interface are returned. This mechanism 
is independent of the AWTEvent, ViewEvent, RequestEvent 
paths . 

25 Iteration can be performed over this list and a 

determination can be made what the object types with the 
type of the object, the type of listeners it supported by 
the objects can be identified. Therefore, a process can 
be added to objects as a listener as long as the callback 

30 method is supported. This can be done for any object 
type. This normally includes JTC objects and AWT 
(includes AWT and JFC) objects. 
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For any object, numerous events may be generated. 
These events are associated with an interface. If an 
object is added as a listener to the object for these 
events, the object must implement the numerous methods 
5 associated with the numerous interfaces to support the 
numerous events from the various types of objects. 

After the event arrives, numerous actions may result 
ranging from logging, to tracing, to connecting to a 
network and sending them out of the box, to generating 
10- further events, A tracing program can in fact be a JTC 
program and it can be hooked (traced) while it is tracing 
another JTC program. A graph-tree of programs may be 
built where the root is the top level program and the 
root listens to its children and so forth, until the 
15 leaves are reached and they are just running JTC 
programs . 

Although events such as AWTEvent, ViewEvent, 
RequestEvent, and TopEvent, still occur anywhere in the 
graph, they do not cause the hooking via get JTCs/getAWTs 

20 to start. This is done primarily when the program is 
launched. It could be initiated in the event path. 
Alternatively, the TopEvent may cause the hooking to 
start. For example, the user hits "help" in a 
ViewController that causes a ViewEvent to a RequestEvent 

25 to launch a request for help and it also sends a TopEvent 
to trace the program and send the events to a call center 
over the network. 

With reference next to Figure 123, a diagram 
illustrating nonintrusive caching, tracing, or logging 

30 using an architectural pattern is depicted in accordance 
with a preferred embodiment of the present invention. 
Pattern 12300 in Figure 123 shows how non-intrusive 
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caching, tracing, or logging can be added to any thin 
client pattern* The main sequence of events from the 
application perspective is ViewEvents generated in the 
ViewControllers 12302 being handled by the 
5 ApplicationMediator 12304 and translated into appropriate 
RequestEvents . These RequestEvents are passed on to the 
destination 12308 via the transported 12306. A 
SnooperApplicationMediator 12310 runs in parallel with 
the application. The SnoopListener monitors ViewEvents 

10 and RequestEvents and, as appropriate, issues 
RequestEvents to the logging system. The 
SnoopDestination 12312 can log, trace or cache 
information on an appropriate storage device 12314. 
Thus, the present invention provides an 

15 architectural pattern that may be used to create Internet 
friendly Java applications, which are small, fast, and 
flexible. Additionally, through the architectural 
pattern of the present invention, the object reuse on a 
client may be between 50 to 100 percent. Additionally, 

20 the architectural pattern and methodology of the present 
invention reduces the time needed to develop an 
application. By the separation of the functions and 
processes as described above, a client application may be 
designed, implemented, and tested as parallel tasks in 

25 the client application. By the separation of the 

functions and processes as described above, a client 
application may be designed, implemented, and tested in 
parallel with the server application. Through the 
present invention, lock-step designing and testing may be 

30 eliminated. The addition of new network protocols, new 
servers and new data models are straight forward and 
easily performed. Also, changing the graphical user 
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interface to change the look and feel of an application 
also is easily performed through the compartmentalization 
and segregation of duties and functions set out in the 
architectural pattern of the present invention. 
5 It is important to note that while the present 

invention has been described in the context of a fully 
functioning data processing system, those of ordinary 
skill in the art will appreciate that the processes of 
the present invention are capable of being distributed in 

10 the form of a computer readable medium of instructions 
and a variety of forms and that the present invention 
applies equally regardless of the particular type of 
signal bearing media actually used to carry out the 
distribution. Examples of computer readable media 

15 include recordable-type media such a floppy disc, a hard 
disk drive, a RAM, and CD-ROMs and transmission-type 
media such as digital and analog communications links. 

The description of the present invention has been 
presented for purposes of illustration and description, 

20 but is not intended to be exhaustive or limited to the 
invention in the form disclosed. Many modifications and 
variations will be apparent to those of ordinary skill in 
the art. For example, although the depicted architectural 
pattern is illustrated in a Java programming environment, 

25 the architectural pattern of the present invention may be 
applied to other types of programming environments. For 
example, VisualBasic, C++ and Smalltalk are other 
programming environments in which the processes of the 
present invention may be applied- In addition, the 

30 description of the classes along with the variables, 

constructors, and methods are provided for purposes of " 
illustration only. Classes, variables, constructors, and 
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methods may vary depending on the particular 
implementation. Illustration of these classes, 
variables, constructors are for illustrative purposes and 
not intended to limit the architectural pattern of the 
5 present invention. The embodiment was chosen and 

described in order to best explain the principles of the 
invention, the practical application, and to enable 
others of ordinary skill in the art to understand the 
invention for various embodiments with various 
10 modifications as are suited to the particular use 
contemplated. 
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CLAIMS: 

What is claimed is: 

1. A method in a data processing system for executing 
5 and processing data in an object oriented environment, 

the method comprising the data processing system 
implemented steps of: 

controlling a presentation of a graphical user 
interface using a view controller, wherein the view 
10 controller handles user input to the graphical user 
interface; 

responsive to a selected user input, sending the 
selected user input from the view controller to an 
application mediator; 
15 responsive to receiving the selected user input at 

the application mediator, processing the selected user 
input at the application mediator; 

responsive to a requirement for data, sending a 
request from the application mediator to a transporter; 
20 responsive to receiving a request from the 

application mediator at the transporter, sending the 
request to a destination; and 

responsive to receiving the request at the 
destination, retrieving the data using the destination. 

25 

2. The method of claim 1, wherein the graphical user 
interface is a component. 

3. The method of claim 1, wherein the graphical user 
30 interface is a plurality of components. 

4. The method of claim 1 further comprising: 
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applying validation rules to user input to validate 
and format the selected user input. 

5. The method of claim 1, wherein the destination is a 
5 selected destination within the plurality of 

destinations . 

6. The method of claim 1, wherein the object oriented 
environment is Java. 

10 

7 . A method in a data processing system creating an 
application for processing data in an object oriented 
system, the method comprising the data processing system 
implemented steps of: 

15 creating a graphical user interface, wherein 

graphical user interface includes a plurality of 
components, processes for presenting the plurality of 
components and receiving user input are handled by a 
first set of graphical objects, wherein in response to 

20 selected user input, a first event is generated; 

creating an application object, wherein the 
application process controls a order in which the 
graphical objects present the set of graphical object 
containers and process the event and wherein the 

25 application generates a second event; 

creating a transport object, wherein the transport 
object processes the second event and forwards the second 
event for processing to a destination within the 
plurality of destinations; and 

30 creating a plurality of destination objects, wherein 

each destination object within the plurality of 
destinations objects handles accessing a destination 



155 

Docket No. AT9-99-339 



within the plurality of destinations. 

8. The method of claim 7, wherein the plurality of 
destinations are a plurality of services located on a 

5 server or on the local system to which the data 
processing system is a client. 

9. The method of claim 7, wherein the plurality of 
destination are a plurality of services located within 

10 the data processing system. 

10. The method of claim 8, wherein the plurality of 
services is a plurality of databases. 

15 11. The method of claim 7, wherein the second event is a 
request for data. 

12. The method of claim 7, wherein the second event is a 
requests to alter data. 

20 

13. A data processing system comprising: 

a view controller, wherein the view controller 
handles presentation of a graphical user interface and 
receives user input; 
25 an application mediator, wherein the application 

mediator receives selected user input from the view 
controller and processes the selected user input and 
generates a request; 

a destination, wherein the destination handles the 
30 request in response to receiving the request; and 

a transporter, wherein the transporter routes the ~ 
request to the from the application mediator to "the 
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14. The data processing system of claim 13, wherein the 
view controller is a first view controller and further 

5 comprising a second view controller, wherein application 
mediator controls the first view controller and the 
second view controller. 

15. A data processing system of claim 13, wherein the 
10 destination is a first destination and further 

comprising; 

a second destination, wherein the second destination 
handles the request in response to receiving the request; 
and 

15 wherein the transporter routes the request to one of 

the first destination and the second destination based on 
contents within the request. 

16. A data processing system for executing and 

20 processing data in an object oriented environment, the 
data processing system comprising: 

controlling means for controlling a presentation of 
a graphical user interface using a view controller, 
wherein the view controller handles user input to the 
25 graphical user interface; 

sending means for responsive to a selected user 
input, for sending the selected user input from the view 
controller to an application mediator; 

processing means, responsive to receiving the 
30 selected user input at the application mediator, for 
processing the selected user input at the application 
mediator; 
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sending means, responsive to a requirement for data, 
for sending a request from the application mediator to a 
transporter; 

sending means, responsive to receiving a request 
5 from the application mediator at the transporter, for 
sending the request to a destination; and 

receiving means, responsive to receiving the request 
at the destination, for retrieving the data using the 
destination. 

10 

17. The data processing system of claim 16, wherein the 
graphical user interface is a component* 

18. The data processing system of claim 16, wherein the 
15 graphical user interface is a plurality of components. 

19. The data processing system of claim 16 further 
comprising: 

applying means for applying validation rules to user 
20 input to validate and format the selected user input. 

20. The data processing system of claim 16, wherein the 
destination is a selected destination within the 
plurality of destinations. 

25 

21. The data processing system of claim 16, wherein the 
object oriented environment is Java. 

22. A data processing system creating an 'application for 
30 processing data in an object oriented system, the data 

processing system comprising: 

first creating means for creating a graphical user 
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interface, wherein graphical user interface includes a 
plurality of components, processes for presenting the 
plurality of components and receiving user input are 
handled by a first set of graphical objects, wherein in 
5 response to selected user input, a first event is 
generated; 

second creating means for creating an application 
object, wherein the application process controls a order 
in which the graphical objects present the set of 
10 graphical object containers and process the event and 
wherein the application generates a second event; 

third creating means for creating a transport 
object, wherein the transport object processes the second 
event and forwards the second event for processing to a 
15 destination within the plurality of destinations; and 
fourth creating means for creating a plurality of 
destination objects, wherein each destination object 
within the plurality of destinations objects handles 
accessing a destination within the plurality of 
20 destinations. 

23. The data processing system of claim 22, wherein the 
plurality of destinations are a plurality of services 
located on a server or on the local system to which the 

25 data processing system is a client. 

24. The data processing system of claim 22, wherein the 
plurality of destination are a plurality of services 
located within the data processing system. 

30 

25. The data processing system of claim 24, wherein the 
plurality of services is a plurality of databases. 
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26. The data processing system of claim 22, wherein the 
second event is a request for data. 

5 27. The data processing system of claim 22, wherein the 
second event is a requests to alter data. 

28. A computer program product in a computer readable 

medium for executing and processing data in an object 
10 oriented environment, the method comprising the computer 

program product implemented steps of: 

first instructions for controlling a presentation of 

a graphical user interface using a view controller, 

wherein the view controller handles user input to the 
15 graphical user interface; 

second instructions, responsive to a selected user 

input, for sending the selected user input from the view 

controller to an application mediator; 

third instructions, responsive to receiving the 
20 selected user input at the application mediator, for 

processing the selected user input at the application 

mediator; 

fourth instructions, responsive to a requirement for 
data, for sending a request from the application mediator 
25 to a transporter; 

fifth instructions, responsive to receiving a 
request from the application mediator at the transporter, 
for sending the request to a destination; and 

sixth instructions, responsive to receiving the 
30 request at the destination, for retrieving the data using 
the destination. 
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29. A computer program product in a computer reaciabel 
medium for creating an application for processing data in 
an object oriented system, the method comprising the 
computer program product implemented steps of: 
5 first instructions for creating a graphical user 

interface, wherein graphical user interface includes a 
plurality of components^ processes for presenting the 
plurality of components and receiving user input are 
handled by a first set of graphical objects, wherein in 
10 response to selected user input, a first event is 
generated; 

second instructions for creating an application 
object, wherein the application process controls a order 
in which the graphical objects present the set of 
15 graphical object containers and process the event and 
wherein the application generates a second event; 

third instructions for creating a transport object, 
wherein the transport object processes the second event 
and forwards the second event for processing to a 
20 destination within the plurality of destinations; and 
fourth instructions for creating a plurality of 
destination objects, wherein each destination object 
within the plurality of destinations objects handles 
accessing a destination within the plurality of 
25 destinations. 



30. A method in a data processing system for refreshing 
data in an application, the method comprising the data 
processing system implemented steps of: 




30 



receiving a change in data at an application 
mediator, wherein the application mediator handles a 
plurality of view controllers and a plurality of 
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application mediators; 

sending a call to each application mediator within 
the plurality of application mediators to refresh data in 
objects associated with the plurality of application 
5 mediators; 

sending a call to each view controller within the 
plurality of view controllers to refresh data in objects 
associated with the plurality of view controllers; 

responsive to receiving a call at an application 
10 mediator within the plurality of application mediators, 
updating the data in an object associated with the 
application mediator, wherein a call is made to each view 
controller to refresh the data; and 

responsive to receiving a call at a view controller 
15 within the plurality of view controllers, updating the 
data in an object associated with the view controller, 
wherein a display of containers presented by the view 
controller is updated. 

20 31. The method of claim 30 further comprising: 

determining, prior to updating the data, whether the 
data is a type recognized and handled by the view 
controller; 

responsive to a determination that the data is an 
25 unrecognized type and handled, formatting the data into 
at least one recognized types by the view controller; 
and 

responsive to a determination that the data is an 
unrecognized type and unhandled, ignoring the data or 
30 yielding an error. 



32. The method of claim 30, wherein the data causes a 
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change in a configuration of components displayed in the 
container, 

33. The method of claim 30, wherein the data contains a 
5 change in permissions resulting in a change in components 

accessible though a user input. 

* 

34. The method of claim 30, wherein each of the 
plurality of view controllers handles presentation of a 

10 container. 

35. The method of claim 30, wherein only a single view 
controller presents a container at a time. 

15 36. The method of claim 30, wherein the container is a 
component . 

37. The method of claim 30, wherein the container is a 
bean. 

20 

38. The method of claim 30, wherein the data is an 
object. 

39. The method of claim 30, wherein the data is an 
25 object containing multiple objects. 

40. A method in a data processing system for refreshing 
data in an application, the method comprising the data 
processing system implemented steps of: 

30 receiving a call to update data in the application, 

wherein the data is destined for a component in the 
application; 
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identifying a data type for the data; and 
responsive to the data type being a handled data 

type, formatting the data and calling a refresh on the 

component . 

5 

41. The method of claim 40, wherein handled data type is 
a singleton. 

42. The method of claim 40, wherein the handled data 
10 type is an aggregate. 

43. The method of claim 40 further comprising: 
responsive to the data type being an unhandled data 

type, determining whether the data contains multiple 
15 object; 

responsive to the data containing a set of objects, 
formatting each object within the set of objects into a 
recognized format; and 

calling a refresh on the component. 

20 

44. The method of claim 40, wherein the component is a 
view controller. 

45. The method of claim 40, wherein the component is an 
25 application mediator 

46. A data processing system for refreshing data in an 
application, the data processing system comprising: 

receiving means for receiving a change in data at an 
30 application mediator, wherein the application mediator 
handles a plurality of view controllers and a plurality " 
of application mediators; 
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first sending means for sending a call to each 
application mediator within the plurality of application 
mediators to refresh data in objects associated with the 
plurality of application mediators; 
5 second sending means for sending a call to each view 

controller within the plurality of view controllers to 
refresh data in objects # associated with the plurality of 
view controllers; 

We- 

first updating means, responsive to receiving a call 
10 at an application mediator within the plurality of 

application mediators, for updating the data in an object 
associated with the application mediator, wherein a call 
is made to each view controller to refresh the data; and 
second updating means, responsive to receiving a 
15 call at a view controller within the plurality of view 
controllers, for updating the data in an object 
associated with the view controller, wherein a display of 
containers presented by the view controller is updated. 

20 47. The data processing system of claim 46 further 
comprising: 

determining means for determining, prior to updating 
the data, whether the data is a type recognized and 
handled by the view controller; 

25 formatting means, responsive to a determination that 

the data is an unrecognized type and handled, for 
formatting the data into at least one recognized types 
by the view controller; and 

ignoring means, responsive to a determination that 

30 the data is an unrecognized type and unhandled, for 
ignoring the data or yielding an error. 
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48. The data processing system of claim 46, wherein the 
data causes a change in a configuration of components 
displayed in the container. 

5 49. The data processing system of claim 4 6, wherein the 
data contains a change in permissions resulting in a 
change in components accessible though a user input. 

50. The data processing system of claim 4 6, wherein each 
10 of the plurality of view controllers handles presentation 

of a container. 

51. The data processing system of claim 46, wherein only 
a single view controller presents a container at a time. 

15 

52. The data processing system of claim 46, wherein the 
container is a component. 

53. The data processing system of claim 46, wherein the 
20 container is a bean. 

54. The data processing system of claim 46, wherein the 
data is an object. 

25 55. The data processing system of claim 46, wherein the 
data is an object containing multiple objects. 

56. A data processing system for refreshing data in an 
application, the data processing system comprising: 
30 receiving means for receiving a call to update data 

in the application, wherein the data is destined for a " 
component in the application; 
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identifying means for identifying a data type for 
the data; and 

formatting means, responsive to the data type being 
a handled data type, for formatting the data and calling 
5 a refresh on the component, 

57. The data processing system of claim 56, wherein 
handled data type is a singleton. 

10 58. The data processing system of claim 56, wherein the 
handled data type is an aggregate. 

59. The data processing system of claim 56 further 
comprising: 

15 determining means, responsive to the data type being 

an unhandled data type, for determining whether the data 
contains multiple object; 

formatting means, responsive to the data containing 
a set of objects, for formatting each object within the 
20 set of objects into a recognized format; and 

calling means for calling a refresh on the 
component . 

60. The data processing system of claim 56, wherein the 
25 component is a view controller. 

61. The data processing system of claim 56, wherein the 
component is an application mediator 

30 62. A computer program product in a computer readable 
medium for refreshing data in an application, the 
computer program product comprising: 



? 
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first instructions for receiving a change in data at 
an application mediator, wherein the application mediator 
handles a plurality of view controllers and a plurality 
of application mediators; 
5 second instructions for sending a call to each 

application mediator within the plurality of application 
mediators to refresh' data in objects associated with the 
plurality of application mediators; 

third instructions for sending a call to each view 
10 controller within the plurality of view controllers to 
refresh data in objects associated with the plurality of 
view controllers; 

fourth instructions, responsive to receiving a call 
at an application mediator within the plurality of 
15 application mediators, for updating the data in an object 
associated with the application mediator, wherein a call 
to each view controller to refresh the data is also made; 
and 

fifth instructions, responsive to receiving a call 
20 at a view controller within the plurality of view 
controllers, for updating the data in an object 
associated with the view controller, wherein a display of 
containers presented by the view controller is updated. 

25 63. A computer program product in a computer readable 
medium for refreshing data in an application, the 
computer program product comprising: 

first instructions for receiving a call to update 
data in the application, wherein the data is destined for 

30 a component in the application; 

second instructions for identifying a data type for" 
the data; and 
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third instructions, responsive to the data type 
being a handled data type, for formatting the data and 
calling a refresh on the component. 



64. A method in a data processing system for displaying a 
component or container, the method comprising the data 
processing system implemented steps of: 

displaying the component within a display using a 
first object; 

10 controlling a location of the component within the 

display using a second object, wherein the second object 
controls the location of the component in response to 
receiving an event; and 

selectively displaying the component using a third 

15 object, wherein the third object generates the event. 

65. The method of claim 64, wherein the first object is 
a view controller, the second object is a placement 
listener, and the third object is an application 

20 mediator . 



66. A method in a data processing system for displaying 
a graphical user interface, the method comprising: 
displaying a container for a graphical user 

25 interface using a view controller object; 

controlling a location of each of the plurality of 
containers using a placement object, wherein the 
placement object the places the contain in the graphical 
user interface in response to receiving events; and 

30 generating events using an application mediator 

object, wherein the events are sent to the placement 
object . 
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67. The method of claim 66, wherein the container is a 
panel . 

68. The method of claim 66, wherein the container is a 
button. 

69. A display mechanism for use in a data processing 
system to display a container in a display in the data 
processing system, the display mechanism comprising: 

a first object used to display a graphical user 
interface in the display and to receive user input; 

a second object used to position the graphical user 
interface in the display in response to receiving an 
event; and 

a third object used to generate the events. 

70. The display mechanism of claim 69, wherein the first 
object is a display object and the second object is a 
positioning object. 

71. The display mechanism of claim 70, wherein the 
display object is an instance of a view controller. 

72. The display mechanism of claim 7 0, wherein the 
positioning object is an instance of a placement 
listener. 

73. The display mechanism of claim 69, wherein the 
display mechanism is implemented in Java. 



74. The display mechanism of claim 69, wherein the 
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second object is useable with a plurality of the first 
objects . 

75. The display mechanism of claim 69, wherein the first 
5 object is a view controller, the second object is a 

placement listener, and the third object is an 
application mediator. 

76. The display mechanism of claim 69, wherein the 

10 application mediator generates an event in response to a 
user input to the container. 

77. A data processing system for displaying a component 
or container, the system comprising: 

15 displaying means for displaying the component within 

a display using a first object; 

controlling means for controlling a location of the 
component within the display using a second object, 
wherein the second object controls the location of the 
20 component in response to receiving an event; and 

displaying means for selectively displaying the 
component using a third object, wherein the third object 
generates the event. 

25 78. The system of claim 77, wherein the first object is 
a view controller, the second object is a placement 
listener, and the third object is an application 
mediator. 

30 79. A data processing system for displaying a graphical 
user interface, the system comprising: 

displaying means for displaying a container for a 
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graphical user interface using a view controller object; 

controlling means for controlling a location of each 
of the plurality of containers using a placement object, 
wherein the placement object the places the contain in 
5 the graphical user interface in response to receiving 
events; and 

generating means for generating events using an 
application mediator object, wherein the events are sent 
to the placement object. 

10 

80. The system of claim 79, wherein the container is a 
panel . 

81. The system of claim 79 wherein the container is a 
15 button. 

82. A computer program product implemented in a data 
processing system for displaying a component or container, 
the instructions comprising: 

20 first instructions for displaying the component 

within a display using a first object; 

second instructions for controlling a location of 
the component within the display using a second object, 
wherein the second object controls the location of the 
25 component in response to receiving an event; and 

third instructions for selectively displaying the 
component using a third object, wherein the third object 
n generates the event. 



access to a set of host services, the method comprising 
the data processing system implemented steps of: 




A process in a data processing system for providing 
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controlling a presentation of a graphical user 
interface using a view controller, wherein the view 
controller handles user input to the graphical user 
interface; 

5 responsive to a selected user input, sending the 

selected user input from the view controller to an 
application mediator; 

responsive to receiving the selected user input at 
the application mediator, processing the selected user 
10 input at the application mediator; 

responsive to the application mediator determining 
that a service from a set of host services is required, 
generating an event; and 

responsive to detecting the event at a listener 
15 object, executing a method in the listener object to 

perform the service, wherein interaction with the set of 
host services is provided from the graphical user 
interface . 

20 84. The process of claim 83, wherein the set of host 
services is a desktop program. 

85. The process of claim 83, wherein the service 
executes within an operating system located on the data 

25 processing system, wherein the service shuts down the 
application. 

86. The process of claim 83, wherein the service 
launches an application. 

30 

87. The process of claim 83, wherein the service sends a 
string message for display in the desktop environment. 
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88, The method of claim 83, wherein the service sends a 
title message for display in a window in the desktop 
environment . 

5 

89 • The process of claim 83, wherein the event includes 
a major code identifying a type of event* 

90. The process of claim 89, wherein the event includes 
10 a minor code identifying additional information about the 

type of event. 

91. The process of claim 89, wherein the event includes 
an identification of the source of the event. 

15 

92. The process of claim 83, wherein the event includes 
data to be passed to the service. 

93. A process in a data processing system for managing 
20 services in a desktop environment from an object 

oriented-environment, the process comprising the data 
processing system implemented steps of: 

controlling a presentation of a graphical user 
interface using a view controller, wherein the view 
25 controller handles user input to the graphical user 
interface; 

responsive to a selected user input, sending the 
selected user input from the view controller to an 
application mediator; 
30 responsive to receiving the selected user input at 

the application mediator, processing the selected user 
input at the application mediator; 
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responsive to the application mediator determining 
that a service is required in the desktop environment, 
generating an event; and 

responsive to detecting the event at a listener 
5 object, executing a method in the listener object to 
perform the service in the desktop environment. 

94. The process of claim 93, wherein the process shuts 
down an application in the desktop environment. 

95. The process of claim 93, wherein the process 
launches an application in the desktop environment. 

96. The process of claim 93, wherein the process sends a 
15 string message for display in the desktop environment. 

97. The process of claim 93, wherein the process sends 
title message for display in a window. 

20 98. The process of claim 93, wherein the event includes 
a major code identifying a type of event. 

99. The process of claim 93, wherein the event includes 
a minor code identifying additional information about the 

25 type of event. 

100. The process of claim 93, wherein the event includes 
an identification of the source of the event. 

30 101. The process of claim 93, wherein the event includes 
data to be passed to the desktop environment. 
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102. A data processing system comprising: 
a desktop environment; 

an object oriented environment, wherein the object 
oriented environment includes: 

a plurality of view controllers, wherein the 
plurality of view controllers control display of a 
plurality of containers, such that each view 
controller controls display of a single container 
and handles user input to that container; 

an application mediator, wherein the 
application mediator controls the view controllers 
to control display of the view controllers, 
processes data, and generates an event requiring a 
service from the desktop environment; and 

a toplistener, wherein the detects the event 
and executes a process to invoke the service. 

103. A data processing system for providing access to a 
set of host services, the data processing system 
comprising: 

controlling means for controlling a presentation of 
a graphical user interface using a view controller, 
wherein the view controller handles user input to the 
graphical user interface; 

sending means, responsive to a selected user input, 
for sending the selected user input from the view 
controller to an application mediator; 

receiving means, responsive to receiving the 
selected user input at the application mediator, for 
processing the selected user input at the application 
mediator; 

generating means, responsive to the application 
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mediator determining that a service from a set of host 
services is required, for generating an event; and 

executing means, responsive to detecting the event 
at a listener object, for executing a method in the 
5 listener object to perform the service, wherein 

interaction with the set of host services is provided 
from the graphical user interface, 

104. The data processing system of claim 103, wherein the 
10 set of host services is a desktop program. 

105. The data processing system of claim 103, wherein the 
service executes within an operating system located on 
the data processing system, wherein the service shuts 

15 down the application, 

106. The data processing system of claim 103, wherein the 
service launches an application. 

20 107. The data processing system of claim 103, wherein the 
service sends a string message for display in the desktop 
environment . 

108. The data processing system of claim 103, wherein 

25 the service sends a title message for display in a window 
in the desktop environment. 

109. The data processing system of claim 103, wherein the 
event includes a major code identifying a type of event. 

30 

110. The data processing system of claim 109, wherein the 
event includes a minor code identifying additional 
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information about the type of event. 

111. The data processing system of claim 109, wherein the 
event includes an identification of the source of the 

5 event . 

112. The data processing system of claim 103, wherein the 
event includes data to be passed to the service. 

10 113. A data processing system for managing services in a 

desktop environment from an object oriented-environment, 

the data processing system comprising: 

controlling means for controlling a presentation of 

a graphical user interface using a view controller, 
15 wherein the view controller handles user input to the 

graphical user interface; 

sending means, responsive to a selected user input, 

for sending the selected user input from the view 

controller to an application mediator; 
20 processing means, responsive to receiving the 

selected user input at the application mediator, for 

processing the selected user input at the application 

mediator; 

generating means, responsive to the application 
25 mediator determining that a service is required in the 
desktop environment, for generating an event; and 

executing means, responsive to detecting the event 
at a listener object, for executing a method in the 
listener object to perform the service in the desktop 
30 environment. 



114. "The data processing system of claim 113, wherein the 
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process shuts down an application in the desktop 
environment, 

115. The data processing system of claim 113, wherein the 
5 data processing system launches an application in the 

des ktop environment . 

116. The data processing system of claim 113, wherein the 
data processing system sends a string message for display 

10 in the desktop environment, 

117. The data processing system of claim 113, wherein the 
data processing system sends title message for display in 
a window. 

15 

118. The data processing system of claim 113, wherein the 
event includes a major code identifying a type of event. 

119. The data processing system of claim 118, wherein the 
20 event includes a minor code identifying additional 

information about the type of event. 

120. The data processing system of claim 118, wherein the 
event includes an identification of the source of the 

25 event . 

121. The data processing system of claim 113, wherein the 
event includes data to be passed to the desktop 
environment . 

30 

122. A computer program product in a computer readable 
medium for use in a data processing system for providing 
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access to a set of host services, the computer program 
product comprising: 

first instructions controlling a presentation of a 
graphical user interface using a view controller, wherein 
5 the view controller handles user input to the graphical 
user interface; 

second instructions, responsive to a selected user 
input/ for sending the selected user input from the view 
controller to an application mediator; 
10 third instructions, responsive to receiving the 

selected user input at the application mediator, for 
processing the selected user input at the application 
mediator; 

fourth instructions, responsive to the application 
15 mediator determining that a service from a set of host 
services is required, for generating an event; and 

fifth instructions, responsive to detecting the 
event at a listener object, for executing a method in the 
listener object to perform the service, wherein 
20 interaction with the set of host services is provided 
from the graphical user interface. 

123. A computer program product in a computer readable 
medium for use in a data processing system for managing 
25 services in a desktop environment from an object 
oriented-environment, the computer program product 
comprising: 

first instructions for controlling a presentation of 
a graphical user interface using a view controller, 
30 wherein the view controller handles user input to the 
graphical user interface; 

second instructions, responsive to a selected user 
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input, for sending the selected user input from the view 
controller to an application mediator; 

third instructions, responsive to receiving the 
selected user input at the application mediator, for 
5 processing the selected user input at the application 
mediator; 



event at a listener object, for executing a method in the 
listener object to perform the service in the desktop 
environment . 



15X^124 . A method in a data processing system for managing 
requests, the method comprising the data processing 
system implemented steps of: 

receiving a request event at a transporter object, 
wherein the request event is self identifying through its 
20 type, a major code, a minor code, and object data, 
identifying a destination object within the 
plurality of destination objects using the request event 
to form an identified destination object; and 



25 destination object, wherein the identified destination 
object handles the request using the indication and 
accesses the target. 

125. The method of claim 124, wherein the target is a 
30 service. 



fourth instructions, responsive to the application 
mediator determining that a service is required in the 
desktop environment, for generating an event; and 

fifth instructions, responsive to detecting the 




sending the request event to the identified 



126. The method of claim -125, wherein the service is 
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located on a remote data processing system. 

127. The method of claim 124, wherein the transporter 
receives the request event from an application mediator. 

128. The method of claim 124, wherein the indication is 
to access a service at a remote location and further 

comprising: 

responsive to receiving the request at the 
destination object, accessing the service at the remote 
location using the destination object, wherein the 
destination object formats the request into one 
recognizable by the remote server to access the service. 

11 15 129, The method of claim 128 further comprising: 
^ receiving a response from the remote service ; 

,|: formatting the response into a request event; and 

[ Jf returning the request event to the transporter. 

ji: 20 130. The method of claim 129, wherein the request event 

f!j includes the data. 

g| 131. The method of claim 129, wherein the remote service 

is a database. 

25 

132. A data processing system comprising: 

a plurality of destination objects, wherein 
responsive to receiving a request event having a first 
indication and a second indication, a destination object 
30 within the plurality of destination objects identifies a 
function to perform on request event, wherein the 
function is identified from a second indication in the 



5 



10 
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request event; and 

a transporter object/ wherein, responsive to 
receiving the request event, the transporter object 
identifies the destination within the plurality of 
5 destinations from the first indication, and routes the 
request to the destination, 

133. The data processing system of claim 132, wherein the 
first indication is a major code and the second 

10 indication is a minor code* 

134. The data processing system of claim 133, wherein the 
major code is a class name of the destination object and 
the minor code is a method name that is to be invoked, 

15 

135. The data processing system of claim 132, wherein the 
request event includes data. 

136. A data processing system for managing requests, the 
20 data processing system comprising: 

receiving means for receiving a request event at a 
transporter object, wherein the request event is self 
identifying through its type, a major code, a minor code, 
and object data. 
25 identifying means for identifying a destination 

object within the plurality of destination objects using 
the request event to form an identified destination 
object; and 

sending means for sending the request event to the 
30 identified destination object, wherein the identified 
destination object handles the request using the 
indication and accesses the target. 



183 

Docket No. AT9-99-339 



136. The data processing system of claim 136, wherein the 
target is a service. 

138. The data processing system of claim 137, wherein the 
service is located on a remote data processing system. 

139. The data processing system of claim 136, wherein the 
transporter receives the request event from an 
application mediator. 

140. The data processing system of claim 136, wherein the 
indication is to access a service at a remote location 
and further comprising: 

accessing means, responsive to receiving the request 
at the destination object, for accessing the service at 
the remote location using the destination object, wherein 
the destination object formats the request into one 
recognizable by the remote server to access the service. 

141. The data processing system of claim 140 further 
comprising: 

second receiving means for receiving a response from 
the remote service; 

formatting means for formatting the response into a 
-request event; and 

returning means for returning the request event to 
the transporter. 

142. The data processing system of claim 141, wherein the 
request event includes the data. 
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143. The data processing system of claim 141, wherein the 
remote service is a database. 

144. A computer program product in a computer readable 
medium for use in data processing system for managing 
requests, the computer program product comprising: 

first instructions for receiving a request event at 
a transporter object, wherein the request event is self 
identifying through its type, a major code, a minor code, 
and object data. 

second instructions for identifying a destination 
object within the plurality of destination objects using 
the request event to form an identified destination 
object; and 

third instructions for sending the request event to 
the identified destination object, wherein the identified 
destination object handles the request using the 
.indication and accesses the target. 



20/V145. A method in a data processing system for displaying 



a graphical user interface, the method comprising the 
data processing system implemented steps of: 

displaying a container in a graphical user interface 
from a set of containers, wherein a display of the 
25 container handled by a view controller from a set of view 
controllers, wherein each view controller handles the 
display of an associated container within the set of 
containers and user input for the associated container; 
and 

30 altering a display of the set of containers by an 

application mediator, wherein the set of containers are 
displayed in an order determined by the application 
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mediator, 

146 • The method of claim 145 further comprising: 

generating an event by a view controller in response 
to a selected user input to a container handled by the 
view controller, wherein the altering step is responsive 
to the application mediator receiving the event- 

147. The method of claim 145, wherein the set of 
containers is a set of panels. 

148. A method in a data processing system for displaying 
a set of containers, the method comprising the data 
processing system implemented steps of: 

displaying a current container from a set of 
containers using a plurality of view controllers, wherein 
each view controller handles user input for a container 
within the set of containers; 

responsive to a selected user input to the current 
container, sending the selected user input from the view 
controller to an application mediator; and 

responsive to receiving the selected user input at 
the application mediator, sending a response to the 
plurality of view controllers to display a different 
container within the set of containers. 

14 9. The method of claim 148, wherein the set of 
containers is a set of panels. 

150. The method of claim 148, wherein the selected input 
is a first selected user input and further comprising: 
responsive to a second selected user input to the 
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current container, sending the second selected user input 
from the view controller to an application mediator; and 

responsive to receiving the second selected user 
input at the application mediator, sending a view 
5 controller for the current container to alter a 
presentation of the current container. 

151. A data processing system comprising: 

a plurality of containers, wherein a current 
10 container is displayed; 

a plurality of view controllers, wherein the view 
controllers control a display of the plurality of 
containers in which each view controller controls a 
single container within the plurality of containers and 
15 generates an event in response to a selected user input; 
and 

an application mediator, wherein the application 
mediator handles the selected event and sends a response 
to a view controller within the plurality of view 
20 controllers, causing another container to be displayed in 
place of the current container. 

152. The data processing system of claim 151, wherein the 
application mediates access to a service. 

25 

153. The data processing system of claim 152, wherein the 
service is a database. 

154. A data processing system for displaying a graphical 
30 user interface, the data processing system comprising: 

displaying means for displaying a container in a 
graphical user interface from a set of containers, 
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wherein a display of the container handled by a view 
controller from a set of view controllers, wherein each 
view controller handles the display of an associated 
container within the set of containers and user input for 
5 the associated container; and 

altering means for altering a display of the set of 
containers by an application mediator, wherein the set of 
containers are displayed in an order determined by the 
application mediator. 

10 

155. The data processing system of claim 154 further 
comprising: 

generating means for generating an event by a view 
controller in response to a selected user input to a 
15 container handled by the view controller, wherein the 

altering step is responsive to the application mediator 
receiving the event. 

156. The data processing system of claim 154, wherein the 
20 set of containers is a set of panels. 

157. A data processing system for displaying a set of 
containers, the data processing system comprising: 

displaying means for displaying a current container 
25 from a set of containers using a plurality of view 

controllers, wherein each view controller handles user 
input for a container within the set of containers; 

sending means, responsive to a selected user input 
to the current container, for sending the selected user 
30 input from the view controller to an application 
mediator; and 

sending means, responsive to receiving the selected 
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user input at the application mediator, for sending a 
response to the plurality of view controllers to display 
a different container within the set of containers. 

158. The data processing system of claim 157, wherein the 
set of containers is a set of panels. 

159. The data processing system of claim 157, wherein the 
selected input is a first selected user input and further 
comprising: 

sending means, responsive to a second selected user 
input to the current container, for sending the second 
selected user input from the view controller to an 
application mediator; and 

sending means, responsive to receiving the second 
selected user input at the application mediator, for 
sending a view controller for the current container to 
alter a presentation of the current container. 

160. A computer program product in a computer readable 
medium for displaying a graphical user interface, the 
method comprising the computer program product 
implemented steps of: 

first instructions for displaying a container in a 
graphical user interface from a set of containers, 
wherein a display of the container handled by a view 
controller from a set of view controllers, wherein each 
view controller handles the display of an associated 
container within the set of containers and user input for 
the associated container; and 

second instructions for altering a display of the 
set of < containers by an application mediator, wherein the 
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set of containers are displayed in an order determined by 
the application mediator. 

161. A computer program product in a computer readable 
5 medium for displaying a set of containers, the method 

comprising the computer program product implemented steps 
of: 



container from a set of containers using a plurality of 
10 view controllers, wherein each view controller handles 
user input for a container within the set of containers; 

second instructions, responsive to a selected user 
input to the current container, for sending the selected 
user input from the view controller to an application 



15 mediator; and 

third instructions, responsive to receiving the 
selected user input at the application mediator, for 
sending a response to the plurality of view controllers 
to display a different container within the set of 

20 containers . 



162 • A method in a data processing system for performing 
validation of user input, the method comprising the data 
processing system implemented steps of: 



graphical user interface, wherein display of the 
container and the user input to the container are handled 
by a view controller; 

responsive to receiving the user input, sending a 
30 call to a validation object; and 

responsive to receiving the call, testing, by the 
validation object, the user input using a set of 



first instructions for displaying a current 




25 



receiving user input to a container displayed in a 
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validation rules. 

163. The method of claim 162, wherein a validation rule 
in the set of validation rule is associated with another 
validation rule in the set of chained validation rules 
and passes the data to the another validation rule in 
response to the user input being validated the validation 
rule 

164. The method of claim 162, wherein the step of testing 
comprises : 

placing data from the user input to be validated in 
a data structure; and 

iteratively testing the data using the set of 
validation rules. 

165. The method of claim 162, wherein the set of 
validation rules is a set of associated validation rules. 

166. The method of claim 162, wherein the set of 
associated validation rules are associated by chaining 
each validation rule within the set of associated 
validation rules with another validation rule within the 
set of validation rules. 

167. A method in a data processing system for performing 
validation of user input, the method comprising the data 
processing system implemented steps of: 

receiving user input in a container displayed in a 
graphical user interface, wherein presentation of the 
container and the user input to the container are handled 
by a view controller; 
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responsive to receiving the user input, sending, by 
the view controller, a call to a validation object; and 

responsive to the call, testing, by the validation 
object, the user input using a criteria, wherein the rule 
is separate from the view controller. 

168. The method of claiiu 167, wherein the criteria is a 
rule. 

169. The method of claim 167, wherein the criteria is a 
set of rules. 

170. The method of claim 167, wherein the set of rules are 
a chained set of rules. 

171. The method of claim 167, wherein the call is a first 
type of call and further comprising: 

responsive to a second type of call, formatting, by 
the validation object, the user input. 

172. The method of claim 167, wherein the container is a 
component . 

173. A data processing system comprising: 

a view controller, wherein the view controller 
handles a display of a container in a graphical user 
interface and handles user input to the container; and 

a validation object, wherein the validation object 
includes a rule used to test data in response to a call 
from the view controller. 

174. A data processing system for performing validation 
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of user input, the data processing system comprising: 
receiving means for receiving user input to a 

container displayed in a graphical user interface, 

wherein display of the container and the user input to 
5 the container are handled by a view controller; 

sending means, responsive to receiving the user 

input, for sending a call to a validation object; and 

testing means, responsive to receiving the call, for 

testing, by the validation object, the user input using a 
10 set of validation rules. 

175. The data processing system of claim 174, wherein a 
validation rule in the set of validation rule is 
associated with another validation rule in the set of 
15 chained validation rules and passes the data to the 

another validation rule in response to the user input 
being validated the validation rule. 

17 6. The data processing system of claim 174, wherein the 
20 testing means comprises: 

placing means for placing data from the user input 
to be validated in a data structure; and 

testing means for iteratively testing the data using 
the set of validation rules. 

25 

177. The data processing system of claim 174, wherein the 
set of validation rules is a set of associated validation 
rules . 

30 178. The data processing system of claim 174, wherein the 
set of associated validation rules are associated by 
chaining each validation rule within the set of 
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associated validation rules with another validation rule 
within the set of validation rules. 

179. A data processing system for performing validation of 
5 user input, the data processing system comprising: 

receiving means for receiving user input in a 

container displayed in a graphical user interface, wherein 

presentation of the container and the user input to the 

container are handled by a view controller; 
10 sending means, responsive to receiving the user 

input, for sending, by the view controller, a call to a 

validation object; and 

testing means, responsive to the call, for testing, 

by the validation object, the user input using a 
15 criteria, wherein the rule is separate from the view 

controller. 

180. The data processing system of claim 179, wherein the 
criteria is a rule. 

20 

181. The data processing system of claim 179, wherein the 
criteria is a set of rules. 

182. The data processing system of claim 179, wherein the 
25 set of rules are a chained set of rules. 

183. The data processing system of claim 179, wherein the 
call is a first type of call and further comprising: 

formatting means, responsive to a second type of 
30 call, formatting, by the validation object, the user 
input . 
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184. The data processing system of claim 167, wherein the 
container is a component. 

185. A computer program product in a computer readable 
medium for use in a data processing system for performing 
validation of user input, the computer program product 
comprising: 

first instructions for receiving user input to a 
container displayed in a graphical user interface, 
wherein display of the container and the user input to 
the container are handled by a view controller; 

second instructions, responsive to receiving the 
user input, for sending a call to a validation object; 
and 

third instructions, responsive to receiving the 
call, for testing, by the validation object, the user 
input using a set of validation rules. 

186. A computer program product in a computer readable 

20 medium for use in a data processing system for performing 
validation of user input, the computer program product 
comprising: 

first instructions for receiving user input in a 
container displayed in a graphical user interface, wherein 

25 presentation of the container and the user input to the 
container are handled by a view controller; 

second instructions, responsive to receiving the user 
input, for sending, by the view controller, a call to a 
validation object; and 

30 third instructions, responsive to the call, for 

testing, by the validation object, the user input using a 
criteria, wherein the rule is separate from the view 



10 
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controller. 



// 187. A method in a data processing system for managing 

permissions in an application, the method comprising the 
5 data processing system implemented steps of: 

receiving a user input changing a security level for 
the application at a container handled by a view 
controller; 

generating a view event describing the user input; 
10 receiving the view event at an application mediator; 

responsive to receiving the view event, sending a 
request event in response to the receiving the view 
event; and 

receiving at the application mediator, a permission 
15 corresponding to the security level, wherein the 
permission alters an item in the application. 

188. The method of claim 187, wherein the item is content 
in the container and further comprising: 

20 sending the permission to the view controller, 

wherein the permission selectively alters content within 
the container . 

189. The method of claim 187, wherein the item is a 
25 function in the application mediator. 

190. The method of claim 187, wherein the user input 
changing the security level is a user login to the 
application. 

30 

191 • The method of claim 187, wherein the content altered 
using the set of permissions is an enablement of a 
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function, 

192. The method of claim 187, wherein the content altered 
using the set of permissions is a disablement of a 

5 function. 

193. The method of claim 187, wherein the set of 
permissions is a set of key/value pairs, wherein a key is 
used to identify content and a value is used to identify 

10 a setting for the content. 

194. A method in a data processing system for managing 
permissions in an application, the method comprising the 
data processing system implemented steps of: 

15 receiving a user input at a container handled by a 

view controller, wherein the user input requests a change 
in permissions in the application; 

generating a view event describing the user inputs- 
receiving the view event at an application mediator; 
20 responsive to receiving the view event, retrieving 

by the application mediator, a set of permissions 
corresponding to the user input; 

sending the set of permissions to the view 
contro ller ; and 
25 selectively altering content within the container 

using the set of permissions. 

195. The method of claim 194, wherein the step of 
selectively altering the content includes: 

30 enabling content within the container. 



196. The method of claim 195, wherein the content enabled 
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is a button. 

197. The method of claim 194, wherein the step of 
selectively altering the contents includes; 

5 disabling content within the container, 

198. The method of claim 196, wherein the content 
disabled is a text field. 

10 199. The method of claim 194, wherein the set of 

permissions includes a plurality of key and value pairs, 
wherein a key in a key and value pair identifies an 
alterable item and a value in the key and value pair 
identifies a setting for the alterable item. 

15 

200. The method of claim 194, wherein the user input is a 
selection of a button. 

201. The method of claim 194, wherein the set of 
20 permissions are associated with a user profile. 

202. The method of claim 194, wherein the user input is a 
change in security. 

25 203. A data processing system comprising: 

a view controller, wherein the view controller 
handles presenting a container, handles input to the 
container, generates a view event in response to a 
selected user input, and alters content in the container 
30 in response to a change in permissions; and 

an application mediator, wherein the application - 
mediator receives the view event, obtains permissions for 
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content in the container in response to the view event 
indicating a request to change permissions for the 
content, and sends the permissions to the view controller 
to set the permissions in the view controller. 

204. The data processing system of claim 203, wherein the 
container is a panel, 

205. The data processing system of claim 203, wherein the 
permissions are a set of key/value pairs, wherein a key 
in a key/value pair identifies alterable content and a 
value in the key/value pair identifies a setting for the 
alterable content. 

206. The data processing system of claim 203, wherein 
permissions are associated with a user profile. 

207. The data processing system of claim 203 further 
comprising: 

a plurality of view controllers, wherein each view 
controller within, the plurality 'of view controllers 
handles a container and wherein the container includes 
content, which is alterable by permissions, and wherein 
the application mediator handles permissions for the 
plurality of view controllers. 

208. A data processing system for managing permissions in 
an application, the data processing system comprising: 

first receiving means for receiving a user input 
changing a security level for the application at a 
container handled by a view controller; 

generating means for generating a view event 
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describing the user input; 

second receiving means for receiving the view event 
at an application mediator; 

sending means, responsive to receiving the view 
5 event, for sending a request event in response to the 
receiving the view event; and 

third receiving means for receiving at the 
application mediator, a permission corresponding to the 
security level, wherein the permission alters an item in 
10 the application. 

209. The data processing system of claim 208, wherein the 
item is content in the container and further comprising: 

sending means for sending the permission to the view 
controller, wherein the permission selectively alters 
content within the container. 

210. The data processing system of claim 208, wherein the 
item is a function in the application mediator. 

211. The data processing system of claim 208, wherein the 
user input changing the security level is a user login to 
the application. 

25 212. The data processing system of claim 208, wherein the 
content altered using the set of permissions is an 
enablement of a function. 

213. The data processing system of claim 208, wherein the 
30 content altered using the set of permissions is a 
disablement of a function. 
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214. The data processing system of claim 208, wherein the 
set of permissions is a set of key/value pairs, wherein a 
key is used to identify content and a value is used to 
identify a setting for the content. 

215. A data processing system for managing permissions in 
an application, the data processing system comprising: 

first receiving means for receiving a user input at 
a container handled by a view controller, wherein the 
user input requests a change in permissions in the 
application; 

generating means for generating a view event 
describing the user input; 

second receiving means for receiving the view event 
at an application mediator; 

retrieving means, responsive to receiving the view 
event, for retrieving by the application mediator, a set 
of permissions corresponding to the user input; 

sending means for sending the set of permissions to 
the view controller; and 

altering means for selectively altering content 
within the container using the set of permissions. 

216. The data processing system of claim 215, wherein the 
means of selectively altering the content includes: 

enabling means for enabling content within the 
container . 

217. The data processing system of claim 216, wherein the 
content enabled is a button. 

218. The data processing system of claim 215, wherein the 
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means of selectively altering the contents includes: 

disabling means for disabling content within the 
container. 

5 219, The data processing system of claim 217, wherein the 
content disabled is a text field. 

220. The data processing system of claim 215, wherein the 
set of permissions includes a plurality of key and value 
pairs, wherein a key in a key and value pair identifies 
an alterable item and a value in the key and value pair 
identifies a setting for the alterable item. 

221. The data processing system of claim 215, wherein the 
15 user input is a selection of a button. 

222. The data processing system of claim 215, wherein the 
set of permissions are associated with a user profile. 

20 223. The data processing system of claim 215, wherein the 
user input is a change in security. 

224. A computer program product in a computer readable 
medium for managing permissions in an application, the 
25 computer program product comprising: 

first instructions for receiving a user input 
changing a security level for the application at a 
container handled by a view controller; 

second instructions for generating a view event 
30 describing the user input; 

third instructions for receiving the view event at" 
an application mediator; 



10 
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fourth instructions, responsive to receiving the 
view event, for sending a request event in response to 
the receiving the view event; and 

fifth instructions for receiving at the application 
5 mediator, a permission corresponding to the security 
level, wherein the permission alters an item in the 
application, 

225. A computer program product in a computer readable 
10 medium for managing permissions in an application, the 
computer program product comprising: 

first instructions for receiving a user input at a 
container handled by a view controller, wherein the user 
input requests a change in permissions in the 
15 application; 

second instructions for generating a view event 
describing the user input; 

third instructions for receiving the view event at 
an application mediator; 
20 fourth instructions, responsive to receiving the 

view event, for retrieving by the application mediator, a 
set of permissions corresponding to the user input; 

fifth instructions for sending the set of 
permissions to the view controller; and 
25 sixth instructions for selectively altering content 

within the container using the set of permissions • 

22 6. A computer program product in a computer readable 
medium comprising: 
30 first instructions for a view controller, wherein 

the view controller handles presenting a container, 
handles input to the container, generates a view event in 
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response to a selected user input, and alters content in 
the container in response to a change in permissions; and 

second instructions for an application mediator, 
wherein the application mediator receives the view event, 
5 obtains permissions for content in the container in 

response to the view event indicating a request to change 
permissions for the content, and sends the permissions to 
the view controller to set the permissions in the view 



/^/227. A process in a data processing system for presenting 
a view to a client, the process comprising the data 
processing system implemented steps of: 

receiving, at an application mediator, a view event 
15 from a view controller, wherein the view event describes 
an action on a displayed container handled by the view 
controller; 

responsive to a requirement that a change in a 
placement of the displayed container is required, 
20 generating a placement event by the application mediator; 

determining, by a placement listener, whether the 
placement event includes an indication that an alternate 
view is to be generated; and 



25 is to be generated, sending a call to a method in the 
view controller to generate the alternate view. 

228. The process of claim 227, wherein the alternate view 
is a hypertext markup language page and wherein a normal 

30 view for the container is a component. 

229. The process of claim 227, wherein the alternate view 




controller . 



responsive to a determination that an alternate view 
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in a a data type definition file. 



230. The process of claim 227 further comprising: 
receiving the call at the view controller; 

5 responsive to receiving the call, generating, by the 

view controller, a markup language version of the 
displayed container. 

231. The process of claim 230 further comprising: 

10 sending the markup language version of the displayed 

container to a client. 



232. The process of claim 231, wherein the step of 
generating, by the view controller, a markup language 
Hp 15 version of the displayed container comprises generating a 

r: hypertext markup language version of the displayed 

JS container. 

m 

* 233. A data processing system comprising: 

S 20 a plurality of view controllers, wherein the 

!TJ plurality of view controllers handle presentation of an 

interface; 

il an application mediator, wherein the application 

mediator handles an order in which the plurality of view 

25 controllers are displayed in a display; and 

a placement listener, wherein the placement listener 
handles placement of the interface in the display, 
wherein the view controller generates a first event 
handled by the application mediator, the application 

30 mediator generates a second event in response to the 
first event requiring a change by a view controller 
within the plurality of view controllers, wherein the 
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placement listener sends a call to the view controller to 
present the container using an alternate mechanism. 

234. The data processing system of claim 233, wherein a 
5 view controller is displayed by causing the view 
controller to present a container in the display. 

'•*■'"' 235. The data processing system of claim 233, wherein the 

alternate mechanism generates a hypertext markup language 
10 file. 

236. The data processing system of claim 233, wherein the 
alternate mechanism is a method in the view controller, 
q wherein the method generates a markup language file 

: fl 15 representing a display of the interface handled by the 

y view controller. 

fa 237. The data processing system of claim 236, wherein the 

^ plurality of view controllers, the application mediator, 

is 

U, 20 and the placement listener are located on the data 

processing system and wherein the data processing system 

\ y 

yj is a server. 

238, The data processing system of claim 237 further 
25 comprising: 

sending means for sending the markup language file 
to a client. 

239. A data processing system for presenting a view to a 
30 client, the data processing system comprising: 

receiving means for receiving, at an application 
mediator, a view event from a view controller, wherein 
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the view event describes an action on a displayed 
container handled by the view controller; 

generating means, responsive to a requirement that a 
change in a placement of the displayed container is 
5 required, for generating a placement event by the 
application mediator; 

determining means for determining, by a placement 
listener, whether the placement event includes an 
indication that an alternate view is to be generated; and 
10 sending means, responsive to a determination that an 

alternate view is to be generated, for sending a call to 
a method in the view controller to generate the alternate 
view. 

15 240. The data processing system of claim 239, wherein the 
alternate view is a hypertext markup language page and 
wherein a normal view for the container is a component. 

241. The data processing system of claim 239, wherein the 
20 alternate view in a a data type definition file. 

242. The data processing system of claim 239 further 
comprising: 

receiving means for receiving the call at the view 
25 controller; 

generating means, responsive to receiving the call, 
for generating, by the view controller, a markup language 
version of the displayed container. 

30 243. The data processing system of claim 242 further 

comprising: - ■ 

sending means for sending the markup language 
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version of the displayed container to a client, 

244 . The data processing system of claim 243, wherein the 
means of generating, by the view controller, a markup 
5 language version of the displayed container comprises 
generating a hypertext markup language version of the 
displayed container. 

245. A computer program product in a computer readable 
10 medium for presenting a view in a data processing system 

to a client, the computer program product comprising: 

first instructions for receiving, at an application 

mediator, a view event from a view controller, wherein 

the view event describes an action on a displayed 
15 container handled by the view controller; 

second instructions, responsive to a requirement 

that a change in a placement of the displayed container 

is required, for generating a placement event by the 

application mediator; 
20 third instructions for determining, by a placement 

listener, whether the placement event includes an 

indication that an alternate view is to be generated; and 
fourth instructions, responsive to a determination 

that an alternate view is to be generated, for sending a 
25 call to a method in the view controller to generate the 

alternate view, 

246. A computer program product in a computer readable 
medium comprising: 

30 first instructions for a plurality of view 

controllers, wherein the plurality of view controllers 
handle presentation of an interface; 
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second instructions for an application mediator, 
wherein the application mediator handles an order in 
which the plurality of view controllers are displayed in 
a display; and 

5 third instructions for a placement listener, wherein 

the placement listener handles placement of the interface 
in the display, wherein ^the view controller generates a 
first event handled by the application mediator, the 
application mediator generates a second event in response 

10 to the first event requiring a change by a view 

controller within the plurality of view controllers, 
wherein the placement listener sends a call to the view 
controller to present the container using an alternate 

A mechanism. 

v 

// 247. A method m a data processing system for processing 
user input in a graphical user interface, the method 
comprising the data processing system implemented step 
of: 

20 presenting a graphical user interface using a view 

controller, wherein the view controller handles the user 
input to the graphical user interface; 

responsive to a selected user input, sending an 
event to a first application mediator; and 

25 responsive to the first application mediator being 

unable to process the event, sending the event to a 
second application mediator for processing, wherein the 
first application mediator and the second application 
mediator handle an order in which a set of displays are 

30 displayed by a view controller. 



248, The method of claim 247, wherein the first 
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application mediator provides a first function and the 
second application mediator provides a second function, 

249. The method of claim 247, wherein the selected user 
5 input is a selection of a button in the graphical user 

interface . 

250. The method of claim 247 , wherein the view controller 
handles presentation of a container, 

10 

251. The method of claim 247, wherein the first 
application mediator is a child of the second application 
mediator . 

15 252. A data processing system comprising: 

a plurality of view controllers associated with a 
set of views, wherein the each view controller within the 
plurality of view controllers handles a view from the set 
of views for a graphical user interface and wherein the 

20 plurality of view controllers generate events in response 
to a selected user input to the set of views; and 

a plurality of application mediators hierarchically 
associated, wherein each application mediator handles 
different functions, a first application mediator on one 

25 level within the plurality of application mediators 
receives an event generated by a view controller, the 
first application mediator sends the event to a second 
application mediator on another level within the 
plurality of application mediators in response to an 

30 inability to process the event by the first application 
mediator. - - 
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253. The data processing system of claim 252, wherein the 
plurality of application mediators include listeners, 
wherein a first level application mediator includes a 
listener for events form the plurality of view 
controllers . 

254. The data processing system of claim 253, wherein a 
second* level application mediator includes a listener to 
the first level application mediator for events from the 
first level application mediator. 

255. The data processing system of claim 252, wherein 
the first application mediator receives the event from 
the view controller. 

256. The data processing system of claim 252, wherein 
the first application mediator receives the event from 
another application mediator on another level within the 
plurality of application mediators. 

257. The data processing system of claim 252, wherein the 
plurality of application mediators form a hierarchy from 
the association, wherein an event first received by an 
application mediator on a lowest level in the hierarchy 
and moves up the hierarchy in response to an application 
mediator in a level of the hierarchy being unable to 
handle the event. 

258. A data processing system for processing user input 
in a graphical user interface, the data processing system 
comprising: 

presenting means for presenting a graphical user 
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interface using a view controller, wherein the view 
controller handles the user input to the graphical user 
interface; 

first sending means, responsive to a selected user 
5 input, for sending an event to a first application 
mediator; and 

second sending means, responsive to the first 
application mediator being unable to process the event, 
for sending the event to a second application mediator 
10 for processing, wherein the first application mediator 
and the second application mediator handle an order in 
which a set of displays are displayed by a view 
controller, 

15 259. The data processing system of claim 258, wherein the 
first application mediator provides a first function and 
the second application mediator provides a second 
function, 

20 260. The data processing system of claim 258, wherein the 
selected user input is a selection of a button in the 
graphical user interface. 

261. The data processing system of claim 258, wherein the 
25 view controller handles presentation of a container. 

262. The data processing system of claim 258, wherein the 
first application mediator is a child of the second 
application mediator. 

30 



2 63. A computer program product in a computer readable 
medium for processing user input in a graphical user 
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interface, the computer program product comprising: 

first instructions for presenting a graphical user 
interface using a view controller, wherein the view 
controller handles the user input to the graphical user 
interface; 

second instructions, responsive to a selected user 
input, for sending an event to a first application 
mediator; and 

third instructions, responsive to the first 
application mediator being unable to process the event, 
for sending the event to a second application mediator 
for processing, wherein the first application mediator 
and the second application mediator handle an order in 
which a set of displays are displayed by a view 
15 controller. 



2 64. A computer program product in a computer readable 
medium comprising: 

first instructions for a plurality of view 
controllers associated with a set of views, wherein the 
each view controller within the plurality of view 
controllers handles a view from the set of views for a 
graphical user interface and wherein the plurality of 
view controllers generate events in response to a 
selected user input to the set of views; and 

second instructions for a plurality of application 
mediators hierarchically associated, wherein each 
application mediator handles different functions, a first 
application mediator on one level within the plurality of 
application mediators receives an event generated by a 
view controller, the first application mediator sends the 
event to a second application mediator on another level 



20 



25 



30 



lift 
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within the plurality of application mediators in response 
to an inability to process the event by the first 
application mediator. 




265. A data processing system comprising: 

a plurality of view controllers, wherein the 
plurality of view controllers handle display of a 
plurality of containers and generate events in response 
to a user input to the plurality of containers; and 
10 a plurality of application mediators, wherein the 

plurality of application mediators handle events from the 
plurality of view controllers/ wherein each of the 
plurality of application mediators include state machine 
used to mange reception and processing events. 

15 

266. The data processing system of claim 265, wherein a 
state machine for an application mediator is initiated by 
reading statements from a data structure. 

20 267. The data processing system of claim 266, wherein the 
data structures is a state machine file. 

268. The data processing system of claim 266, wherein the 
statements define rules for states used to trigger state 
25 transitions and actions associated with the state 
transitions . 



269. The data processing system of claim 268, wherein 
each of the plurality of application mediators are 
30 initiated by reading selected statements from the 
statements in the data structure. 
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270. A method in a data processing system for presenting 
a set of screens in a graphical user interface, the 
method comprising the data processing system implemented 
steps of: 

5 presenting a first screen within a set of screens, 

wherein the set of screens are presented using a set of 
view controllers; 

responsive to a selected user input to the first 
screen, generating an event by a view controller within 
10 the set of view controllers identifying the user input to 
the first screen, which is handled by the first view 
controller; and 

responsive to detecting the event generated by the 
view controller, selecting, by an application mediator, a 
15 second screen from the set of screens for display by 
sending a response to a view controller handling the 
second screen. 

271. The method of claim 270, wherein the screen is a 
20 component . 

272. The method of claim 270, wherein the selecting step 
is performed using a state machine in the application 
mediator . 

273. The method of claim 270, wherein the event includes 
a major code and a minor code. 

274. The method of claim 270, wherein the major code 
indicates an action taken and the minor code indicates a 

30 function to be performed. 




275. The method of claim 270, wherein the application 
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mediator is initialized by reading a file containing a 
set of rules. 

276. The method of claim 275, wherein the set of rules 
5 are a set of transition rules for a state machine* 

277. The method of claiji^ 276, wherein the application 
mediator is initialized using a portion of the set of 
rules ♦ 

10 

278. A data processing system comprising: 

a plurality of screens presented by a plurality of 
view controllers, wherein each view controller is 
associated with a screen, controls presentation of the 
15 screen, controls internal operation of the screen, and 

generates an event in response to a selected input to the 
screen; and 

an application mediator, wherein the application 
mediator receives events from the plurality of view 
20 controllers and provides responses to the plurality of 

view controllers to alter the display of the plurality of 
screens . 

279. The data processing system of claim 278, wherein the 
25 plurality of screens are displayed one screen at a time. 

280. The data processing system of claim 278, wherein the 
plurality of screens are displayed in an order controlled 
by the application mediator. 

30 

281. The data processing system of claim 278, wherein the 
event includes an identification of the user input to a 
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screen and includes data and wherein the application 
mediator provides a function to process the data, 

282, The data processing system of claim 278, wherein the 
application mediator includes a state machine used to 
process events . 

283, The data processing system of claim 278, wherein the 
event includes a major code and a minor code, 

284, The data processing system of claim 278, wherein the 
major code indicates an action taken and the minor code 
indicates a function to be performed. 



15 285. A data processing system for presenting a set of 
screens in a graphical user interface, the data 
processing system comprising: 

presenting means for presenting a first screen 
within a set of screens, wherein the set of screens are 

20 presented using a set of view controllers; 

generating means, responsive to a selected user 
input to the first screen, for generating an event by a 
view controller within the set of view controllers 
identifying the user input to the first screen, which is 

25 handled by the first view controller; and 

selecting means, responsive to detecting the event 
generated by the view controller, for selecting, by an 
application mediator, a second screen from the set of 
screens for display by sending a response to a view 

30 controller handling the second screen. 



28 6. The data processing system of claim 285, wherein the 
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screen is a component, 

287. The data processing system of claim 285, wherein the 
selecting means is performed using a state machine in the 

5 application mediator, 

288. The data processing system of claim 285, wherein the 
event includes a major code and a minor code. 

10 289. The data processing system of claim 285, wherein the 
major code indicates an action taken and the minor code 
indicates a function to be performed. 

290. The data processing system of claim 285, wherein the 
15 application mediator is initialized by reading a file 

containing a set of rules. 

291. The data processing system of claim 290, wherein the 
set of rules are a set of transition rules for a state 

20 machine. 

292. The data processing system of claim 291, wherein the 
application mediator is initialized using a portion of 
the set of rules. 

25 

2 93. A computer program product in a computer readable 
medium comprising: 

first instructions for a plurality of view 
controllers, wherein the plurality of view controllers 
30 handle display of a plurality of containers and generate 
events in response to a user input to the plurality of " " 
containers; and 
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second instructions for a plurality of application 
mediators, wherein the plurality of application mediators 
handle events from the plurality of view controllers, 
wherein each of the plurality of application mediators 
5 include state machine used to mange reception and 
processing events. 

294. A computer program product in a computer readable 
medium for presenting a set of screens in a graphical 
10 user interface, the computer program product comprising: 
first instructions for presenting a first screen 
within a set of screens, wherein the set of screens are 
presented using a set of view controllers; 

second instructions, responsive to a selected user 
15 input to the first screen, for generating an event by a 
view controller within the set of view controllers 
identifying the user input to the first screen, which is 
handled by the first view controller; and 

third instructions, responsive to detecting the 
20 event generated by the view controller, for selecting, by 
an application mediator, a second screen from the set of 
screens for display by sending a response to a view 
controller handling the second screen. 

25 295. A computer program product in a computer readable 
medium comprising: 

first instructions for a plurality of screens 
presented by a plurality of view controllers, wherein 
each view controller is associated with a screen, 

30 controls presentation of the screen, controls internal 
operation of the screen, and generates an event in 
response to a selected input to the screen; and 
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second instructions for an application mediator, 
wherein the application mediator receives events from the 
plurality of view controllers and provides responses to 
the plurality of view controllers to alter the display of 
the plurality of screens, 

296. A method in a data processing system for serializing 
a data' element, the method comprising the data processing 
system implemented steps of: 

receiving the data element for serialization, 
wherein data element includes a class name; 

replacing the class name with an indicator having a 
smaller size than the class name to form a modified data 
element; and 

serializing the modified data element. 

297. The method of claim 296, wherein the step of 
replacing the class name string with an indicator having 
a smaller size than the class name to form a modified 
data element comprises hashing the class name to create a 
hash code and replacing the class name with the hash 
code . 

298. The method of claim 297 further comprising: 
receiving the modified data element; 
deserializing the modified data element; and 
replacing the hash code with the class name string. 

299. The method of claim 296, wherein the data element 
includes a path and wherein the path and the class name 
string are replaced with the indicator. 
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300. The method of claim 296 further comprising: 
determining whether the data element includes a 

class name that is replaceable; and 

responsive to a determination that the data is 
unreplaceable serializing the data element using a 
default process. 

301. The method of claim 296, wherein the steps receiving 
a data element for serialization, wherein data element 
includes a class name; replacing the class name with an 
indicator having a smaller size than the class name to 
form a modified data element are performed at the data 
processing system; and the steps of receiving the 
modified data element; deserializing the modified data 
element; and replacing the hash code with the class name 
are performed at another data processing system. 

302. A method in a data processing system for 
deserializing a data object, the method comprising: 

receiving a data element for deserialization; 
deserializing the data element; and 

replacing an indicator within the data element with 
a class name. 

303. The method of claim 302, wherein the indicator is a 
hash code and wherein the step of replacing an indicator 
within the data element with a class name comprises: 

using the hash code as a key within a hash table to 
identify the class name; and 

replacing the hash code with the class name. 

304. The method of claim 303, wherein the hash code also 
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identifies a base Java class. 

305. The method of claim 304, wherein the data is a base 
Java class path. 

5 

306. A data processing system comprising: 

a serializer having a plurality of modes of 
operation including: 

a first mode of operation in which the 
10 serializer receives a data element for 

serialization, wherein the data element includes a 
class name string; 

a second mode of operation, responsive to 
receiving the data element in which the serializer 
15 replaces the class name string with a code having a 

smaller size than the class name string to form a 
modified data element; and 

a third mode of operation, responsive to 
forming the modified data element, in which the 
20 serializer serializes modified data element. 

307. The data processing system of claim 306, wherein the 
serializer replaces the class name string with a code 
using a hashing function, wherein the code is a hash 

25 code . 

308 . A data processing system for serializing a data 
element, the data processing system comprising: 

receiving means for receiving the data element for 
30 serialization, wherein data element includes a class 
name ; 

replacing means for replacing the class name with an 
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indicator having a smaller size than the class name to 
form a modified data element; and 

serializing means for serializing the modified data 
element . 

5 

309. The data processing system of claim 308, wherein the 
means of replacing the class name string with an 
indicator having a smaller size than the class name to 
form a modified data element comprises hashing the class 

10 name to create a hash code and replacing the class name 
with the hash code. 

310. The data processing system of claim 309 further 
comprising: 

15 receiving means for receiving the modified data 

element; 

deserializing means for deserializing the modified 
data element; and 

replacing means for replacing the hash code with the 
20 class name string. 

311. The data processing system of claim 308, wherein the 
data element includes a path and wherein the path and the 
class name string are replaced with the indicator. 

25 

312. The data processing system of claim 308 further 
comprising: 

determining means for determining whether the data 
element includes a class name that is replaceable; and 
30 serializing means, responsive to a determination 

that the data is unreplaceable, for serializing the data' 
element using a default process. 
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313, The data processing system of claim 308, wherein the 
means of receiving a data element for serialization, 
wherein data element includes a class name; replacing the 

5 class name with an indicator having a smaller size than 
the class name to form a modified data element are 
performed at the data processing system; and the means of 
receiving the modified data element; deserializing the 
modified data element; and replacing the hash code with 
10 the class name are performed at another data processing 
system. 

314, A data processing system for deserializing a data 
object, the data processing system comprising: 

15 receiving means for receiving a data element for 

deserialization; 

deserializing means for deserializing the data 
element; and 

replacing means for replacing an indicator within 
20 the data element with a class name. 

315. The data processing system of claim 314, wherein the 
indicator is a hash code and wherein the means of 
replacing an indicator within the data element with a 

25 class name comprises: 

using means for using the hash code as a key within 
a hash table to identify the class name; and 

replacing means for replacing the hash code with the 
class name. 

30 

316. The data processing system of claim 315, wherein the 
hash code also identifies a base Java class. 
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317. The data processing system of claim 316, wherein the 
data is a base Java class path. 

5 318. A computer program product in a computer readable 
medium for serializing a data element, the computer 
program product comprising: 



for serialization, wherein data element includes a class 
10 name; 

second instructions for replacing the class name 
with an indicator having a smaller size than the class 
name to form a modified data element; and 

third instructions for serializing the modified data 
15 element. 

319. A computer program product in a computer readable 
medium for deserializing a data object, the computer 
program product comprising: 
20 first instructions for receiving a data element for 

deserialization; 

second instructions for deserializing the data 
element; and 

third instructions for replacing an indicator within 
25 the data element with a class name. 



// 320. A method in a data processing system for providing 

an interface to an application for monitoring execution 

of the application, the method comprising the data 
30 processing system implemented steps of: 



first instructions for receiving the data element 




detecting an event generated by a component; 
determining whether the event is an event selected 
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for monitoring; and 

responsive to a determination that the event is an 
event selected for monitoring, generating a request 
event, wherein the request event includes data from the 
5 event and a destination, 

321. The method of claim 320 further comprising: 
routing the request event to a destination object 

through a transporter, wherein the transporter identifies 
10 the destination object based on the destination in the 
request event; 

formatting the request event into a form recognized 
by the destination at the destination object; and 

sending the request event to the destination using a 
15 destination object. 

322. The method of claim 320, wherein the destination is 
a data structure on a second data processing system. 

20 323. The method of claim 320, wherein the destination is 
another application used to monitor the application 

324. The method of claim 320 further comprising: 
performing debugging operations using the data. 

25 

325. The method of claim 320, wherein the steps of 
detecting, determining, generating, routing, formatting, 
and sending are initiated through a call to an interface 
in the application. 

30 

32 6. The method of claim 320, wherein the component is -a" 
ViewController. 
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327. The method of claim 320, wherein the component is a 
Transporter. 

5 328. The method of claim 320, wherein the component is a 
bean. 

329. A method in a data processing system for providing 
an interface to an application for monitoring execution 
10 of the application in an object oriented environment, the 
method comprising the data processing system implemented 
steps of: 

receiving a call to return objects in the 
application; 

15 adding listeners to the objects in the applications- 

monitoring the objects for an event; and 
responsive to detecting an event performing a 
monitoring operation. 

20 330. The method of claim 329, wherein the monitoring 
operation is a debugging function. 

331, The method of claim 329, wherein the monitoring 
operation is a tracing function. 

25 

332. An object oriented application in data processing 
system comprising: 

a plurality of view controllers, wherein the 
plurality of view controllers handle presentation of a 
30 plurality of containers in a graphical user interface and 
generate view events in response to selected user input-,* 
wherein a view event includes an identification of an 
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action taken on a container; 

an application mediator, wherein the application 
mediator includes a listener for receiving view events 
from the plurality of view controllers, processes the 
5 view events, and selectively generates request events 
based on the view events, wherein each request event 
includes a first identifier identifying a destination and 
a second identifier identifying a function to be 
performed; 

10 a plurality of destination objects, wherein each 

destination object is associated with a destination and 
is configured to translate a request event into a form 
recognized by the destination to form a translated 
request event and send the translated request event to 

15 the destination; 

a transporter, wherein the transporter receives view 
events from the application mediator and routes the view 
events to a destination within the plurality of 
destinations based on the first identifier; and 

20 a snooper application mediator, wherein the snooper 

application mediator, includes a listener for receiving 
view events from the plurality of view controllers and 
generates request events having a data structure used to 
monitor the object oriented application as a destination, 

25 wherein the data being monitored is sent to the data 
structure . 

333. The object oriented application of claim 332, 
wherein the snooper application mediator includes a 
30 listener for receiving request events from the 

application mediator. - - 
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334. The object oriented application of claim 333, 
wherein the data is data used to trace execution of the 
application. 

5 335. The object oriented application of claim 333, 

wherein the data includes select view events and the data 
structure is a log file. 

336. The object oriented application of claim 333, 
10 wherein the data is an exception generated by a view 
controller within the plurality of view controllers. 

337* The object oriented application of claim 333, 
wherein the data is an exception generated by the 
15 application mediator. 

338. A data processing system for providing an interface 
to an application for monitoring execution of the 
application, the data processing system comprising: 

20 detecting means for detecting an event generated by 

a component; 

determining means for determining whether the event 
is an event selected for monitoring; and 

generating means, responsive to a determination that 
25 the event is an event selected for monitoring, for 

generating a request event, wherein the request event 
includes data from the event and a destination. 

339. The data processing system of claim 338 further 
30 comprising: 

routing means for routing the request event to a 
destination object through a transporter, wherein the 
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transporter identifies the destination object based on 
the destination in the request event; 

formatting means for formatting the request event 
into a form recognized by the destination at the 
5 destination object; and 

sending means for sending the request event to the 
destination using a destination object* 

340. The data processing system of claim 338, wherein the 
10 destination is a data structure on a second data 

processing system. 

341. The data processing system of claim 338, wherein the 
destination is another application used to monitor the 

15 application 

342. The data processing system of claim 338 further 
comprising: 

performing means for performing debugging operations 
20 using the data. 

343. The data processing system of claim 338, wherein the 
detecting means, determining means, generating means, 
routing means, formatting means, and sending means are 

25 initiated through a call to an interface in the 
application. 

344. The data processing system of claim 338, wherein the 
component is a ViewController . 

30 

345. The data processing system of claim 338, wherein the 
component is a Transporter. 
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346* The data processing system of claim 338, wherein the 
component is a bean. 

5 347. A data processing system for providing an interface 
to an application for monitoring execution of the 
application in an object oriented environment, the data 
processing system comprising: 

receiving means for receiving a call to return 
10 objects in the application; 

adding means for adding listeners to the objects in 
the application; 

monitoring means for monitoring the objects for an 
event; and 

15 performing means, responsive to detecting an event, 

for performing a monitoring operation. 

348. The data processing system of claim 347, wherein the 
monitoring operation is a debugging function. 

20 

349. The data processing system of claim 347, wherein the 
monitoring operation is a tracing function. 

350. A computer program product in a computer readable 
25 medium for providing an interface to an application for 

monitoring execution of the application, the computer 
program product comprising: 

first instructions for detecting an event generated 
by a component; 
30 second instructions for determining whether the 

event is an event selected for monitoring; and - ' 

third instructions, responsive to a determination 
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that the event is an event selected for monitoring, for 
generating a request event, wherein the request event 
includes data from the event and a destination. 

351. A computer program product in a computer readable 
medium for providing an interface to an application for 
monitoring execution of ^the application in an object 
oriented environment, the computer program product 
comprising: 

first instructions for receiving a call to return 
objects in the application; 

second instructions for adding listeners to the 
objects in the application; 

third instructions for monitoring the objects for an 
event; and 

fourth instructions, responsive to detecting an 
event for performing a monitoring operation. 

352. A computer program product in a computer readable 
20 medium: 

first instructions for a plurality of view 
controllers, wherein the plurality of view controllers 
handle presentation of a plurality of containers in a 
graphical user interface and generate view events in 
25 response to selected user input, wherein a view event 
includes an identification of an action taken on a 
container; 

second instructions for an application mediator, 
wherein the application mediator includes a listener for 
30 receiving view events from the plurality of view 

controllers, processes the view events, and selectively 
generates request events based on the view events, 
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wherein each request event includes a first identifier 
identifying a destination and a second identifier 
identifying a function to be performed; 

third instructions for a plurality of destination 
5 objects, wherein each destination object is associated 
with a destination and is configured to translate a 
request event into a form recognized by the destination 
to form a translated request event and send the 
translated request event to the destination; 
10 fourth instructions for a transporter, wherein the 

transporter receives view events from the application 
mediator and routes the view events to a destination 
within the plurality of destinations based on the first 
identifier; and 
15 fifth instructions for a snooper application 

mediator, wherein the snooper application mediator, 
includes a listener for receiving view events from the 
plurality of view controllers and generates request 
events having a data structure used to monitor the object 
20 oriented application as a destination, wherein the data 
being monitored is sent to the data structure. 

353. A process in a data processing system for processing 
an event, the method comprising the data processing 
25 system implemented steps of: 

generating the event at a object in an object 
oriented environment, wherein the event includes a class 
name as a destination and a method name as a function to 
be invoked; and 

30 sending an event from the object to a second object 

oriented environment, wherein the event is used to access 
a method in the second object oriented environment. 
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354. The process of claim 353, wherein the event further 
includes parameters for the method as data. 

355. The process of claim 353, wherein the access is an 
remote invocation of the method. 

356. tfhe process of claim 353, wherein the object is an 
application mediator. 

357. The process of claim 356, wherein the step of 
sending the event to the second environment comprises: 

sending the event to a destination object, wherein 
the destination object translates the event into a format 
recognized in the second object oriented environment. 

358. A process in a data processing system for processing 
events an object oriented system, the method comprising 
the data processing system implemented steps of: 

responsive to receiving a selected user input to a 
container, sending a view event from a view controller to 
an application mediator, wherein the view event 
identifies an action taken to generate the selected user 
input; 

selectively generating a request event based on the 
view event, wherein the request event includes a major 
code identifying a class name as a destination and a 
minor code identifying a method name a function to be 
invoked; and 

sending the request event to a transporter; and 
responsive to receiving the request event at the . - 
transporter, sending the request event to a destination 
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object within a plurality of destination objects based in 
the class name. 

359. The process of claim 358, wherein the action is a 
pressing of a button displayed in the container. 

360. The process of claim 358, wherein each of the 
plurality of destination objects is associated with a 
destination and wherein each of the plurality of 
destination objects translates the request event into a 
format recognizable by the destination. 

361. The process of claim 360, wherein the plurality of 
destinations is a plurality of applications located on a 
remote data processing system having an ability to 
communicate with the data processing system. 

362. The process of claim 361, wherein the request event 
is used to invoke the method at the destination. 

363. The process of claim 358, wherein the request event 
includes data in a form of parameters for the method. 

364. The process of claim 361, wherein the request event 
is used to alter a method at the destination 

365. The process for claim 361, wherein the request is 
event is used access a class located at the destination. 

366. A data processing system for processing an event, 
the data processing system comprising: 

generating means for generating the event at a 
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object in an object oriented environment, wherein the 
event includes a class name as a destination and a method 
name as a function to be invoked; and 

sending means for sending an event from the object 
5 to a second object oriented environment, wherein the 
event is used to access a method in the second object 
oriented environment. 

367. The data processing system of claim 366, wherein the 
10 event further includes parameters for the data processing 

system as data. 

368. The data processing system of claim 366, wherein the 
access is an remote invocation of the data processing 

15 system. 

369. The data processing system of claim 366, wherein the 
object is an application mediator. 

20 370. The data processing system of claim 369, wherein the 
means of sending the event to the second environment 
comprises : 

sending means for sending the event to a destination 
object, wherein the destination object translates the 
25 event into a format recognized in the second object 
oriented environment. 

371. A data processing system for processing events in an 
object oriented system, the data processing system 
30 comprising: 

first sending means, responsive to receiving a 
selected user input to a container, for sending a view 
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event from a view controller to an application mediator, 
wherein the view event identifies an action taken to 
generate the selected user input; 

generating means for selectively generating a 
5 request event based on the view event, wherein the 

request event includes a major code identifying a class 
name as a destination and a -minor code identifying a 
method name a function to be invoked; and 

second sending means for sending the request event 
10 to a transporter; and 

third sending means, responsive to receiving the 
request event at the transporter, for sending the request 
event to a destination object within a plurality of 
destination objects based in the class name. 

15 

372. The data processing system of claim 371, wherein the 
action is a pressing of a button displayed in the 
container. 

20 373. The data processing system of claim 371, wherein 
each of the plurality of destination objects is 
associated with a destination and wherein each of the 
plurality of destination objects translates the request 
event into a format recognizable by the destination. 

25 

374. The data processing system of claim 373, wherein the 
plurality of destinations is a plurality of applications 
located on a remote data processing system having an 
ability to communicate with the data processing system. 

30 

375. The data processing system of claim 374, wherein the 
request event is used to invoke the data processing 
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system at the destination. 

376. The data processing system of claim 371, wherein the 
request event includes data in a form of parameters for 
the data processing system. 

377. The data processing; system of claim 374, wherein the 
request event is used to alter a data processing system 
at the destination 

378. The data processing system for claim 374, wherein 
the request is event is used access a class located at 
the destination. 

379. A computer program product in a computer readable 
medium for processing an event, the computer program 
product comprising: 

first instructions for generating the event at a 
object in an object oriented environment, wherein the 
event includes a class name as a destination and a method 
name as a function to be invoked; and 

second instructions for sending an event from the 
object to a second object oriented environment, wherein 
the event is used to access a method in the second object 
oriented environment. 

380. A computer program product in a computer readable 
medium for processing events an object oriented system, 
the computer program product comprising: 

first instructions, responsive to receiving a 
selected user input to a container, for sending a view 
event from a view controller to an application mediator, 
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wherein the view event identifies an action taken to 
generate the selected user input; 

second instructions for selectively generating a 
request event based on the view event, wherein the 
5 request event includes a major code identifying a class 
name as a destination and a minor code identifying a 
method name a function to be invoked; and 

third instructions for sending the request event to 
a transporter; and 
10 fourth instructions, responsive to receiving the 

request event at the transporter, for sending the request 
event to a destination object within a plurality of 
destination objects based in the class name. 
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ABSTRACT OF THE DISCLOSURE 

MECHANISM FOR CROSS CHANNEL MULTI-SERVER MULT I -PROTOCOL 
5 MULTI-DATA MODEL THIN CLIENTS 

A method and apparatus of an architectural pattern 
for creating applications for a data processing system, 
A graphical user interface is created in which the 

10 graphical user interface includes a plurality of 

components. Processes for presenting the plurality of 
components and receiving user input are handled by a 
first set of graphical objects, wherein in response to 
selected user input, a first event is generated. An 

15 application object is created in which the application 
process controls an order in which the graphical objects 
present the set of components and process the event and 
wherein the application generates a second event. A 
transport object is created in which the transport object 

20 processes the second event and forwards the second event 
for processing to a destination within the plurality of 
destinations. A plurality of destination objects are 
created in which each destination object within the 
plurality of destinations objects handles accessing a 

25 destination within the plurality of destinations. 
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Called back with the results of an asynchronous request. 
By default, call refresh with the data in the respo 


This method is used in style 1 threading. Rename this to 
runO and uncomment the code as described in the class 
javadoc. 
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Set the resources.- By default, call setResources on each 
ViewConrroller and ApplkationMediator 
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A ViewEvent is delivered. Process it using Threading 
style t or 2. In the end, the process ViewEvent will be 
called on the subclass. 
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package comJbm.jtcx.seriaiization; 

import java.io.Externalizable; 
import java.io.IOException; 
import java.io.Objectlnput; 
import java.io.ObjectOutput; 

* Default type comment. 

* <P>1NVARIANT: 
*l 

public class BaseData implements Externalizable { 
private ObjectQ data ~ null; 

* BaseData constructor comment. 
*/ 

public BaseData() { 
thls(O); 

} 

/** 

* BaseData constructor comment. 

* @param dataArray java.lang.ObjectQ 
*/ 

public BaseData(int count) { 
super(); 

setData(new Object[courrt]); 

} 

r* 

* Default method comment. 

* <P>PRE: 

* <P>POST: 

* 

* ©return Parameter not modified 

* ©return java.lang.ObiectQ 
*/ 

public final ObjectQ getData() { 
return data; 

j 



Figure 107 

10700 

pgi 



* Default method comment, 
* 

* <P>PRE: 

* <P>POST: 

* 

* ©return Parameter not modified 

* ©return java.lang .Object Cinnrcs -107 

* @param index int rlyUIC IU/ 

*/ 

public final Object getData(int Index) { 

Object retVai = null; 10700 

P9 2 

if ((data != null) && (index < data.length}) { 
retVai = datapndex]; 

} 

return retVai; 

} 

* Default method comment. 

* <P>PRE: 

* <P>POST: 

* ©return Parameter not modified 

* @param in Objectinput 
*/ 

public void readExtemal(Objectlnput in) 

throws ClassNotFound Exception, lOExceptlon { 

setData((ObjectQ)in.readObject()); 

} 

/** 

* Default method comment. 

* 

* <P>PRE: 

* <P>POST: 

* 

* ©return Parameter not modified 

* @param dataArray Java Jang.ObjectQ 
*/ 

public final void setData(ObjectQ dataArray) { 
data = dataArray; 

} 



Figure 1 



r 

* Default method comment. 

* 

* <P>PRE: 

* <P>POST: 

• 

* ©return Parameter not modified 

* @pararn index int 

* @param dataElement java.lang. Object 
7 

public final void setData(int index, Object dataElement) { 
if ((data !- null) && (index < data.length)) { 
datapndex] = dataElement; 

} 

} 

r 

* Default method comment. 
* 

* <P>PRE: 

* <P>POST: 

* 

* ©return Parameter not modified 

* @param out ObjectOutput 
*/ 

public void writeExtemal(0bject0utput out) throws lOException { 
out.writeObject(getData{)); 

} 
} 



10700 

pg3 



Figure 108 



package comibmjtex.serializatk)n; 
import java. io. Externalizable; 

import java.».IOExceptbn; qqqq 

import ja\fc.b.0bjectlnput; pg ^ 

import java.b.ObjectOutput; 

import jammatkBigDecimal; 

import java.math.BigInteger; 

import java.util Date; 

import java.utilEnumeration; 

import java-utiL GregorianCalendar; 

import java.utfl.Hashtable; 

import java.utilSiirpleTimeZone; 

inport java.utilTinieZoT]e; 

import java. util Vector; 

/** 

* Base class of data objects that require small serialization. The 

* attributes of the data object are stored in an array and the elements 

* of the array are written individually. 
* 

* <P>INVARIANT; 
*/ 

public class BaseDataS extends BaseData implements Externalizable { 
/** 

* Default constructor, 
*/ 

public BaseDataS() { 
superO; 

} 

/** 

* Creates a new <code>BaseDataS</code> object with a data array of 

* size <code>couni</code>. 
* 

* @param count the size of the data array containing the attributes 
*/ 

public BaseDataS(int count) { 
super(count); 



} 



* Reads the array of data elements from the stream The responsibility 

* of reading the individual element is left to the 

* <code>BaseSerializer</code> via <code>readObject()<code>« 



* @param in the input stream that contains the serialized object 
©exception ChssNotFoundException thrown if 

* <code>BaseSerializer</code> &ils to read the object from the stream 
©exception lOException thrown if 

* <code>BaseSerializer</code> foils to read the object from the stream 

* @see BaseSerializer#readObject 
*/ 

public void readExternal(Object!nput in) 

throws OassNotFoundException, lOException { FiQUr© 1 08 

int size = iareadShortO; 

1W 10800 
setData(null); Ky 

}efce { 

Object^ array = new Object[size]; 



&r (int i = 0; i < size; if+) { 

array[i] = BaseSerializer.g#InstaiicsO-readObject(in); 

} 

setData(array); 

} 

} 

* Writes the array of data elements. The responsibility of writing the 

* data elements is left to <code>BaseSerializer</code> via 

* <code>writeObjectO</code>. 

ac 

* @param out the output stream to which the data elements will be 

* written 

*/ 

public void writeExternaI(ObjectOutput out) throws lOException { 
Objectf] array = getDataO; 

if (array =~ null) { 

out. writeS ho rt(-l); 

} else { 

out writeS ho rt(array. length) ; 

for (int i « 0; i < array. length; i++) { 

BaseSeriali2er.getInstance0.writeObject(out, array[i]); 

} 

} 
} 
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package comibm.jtcx.serialization; 

import java.io, IOException; 

import jamb.Objectliput; 

import java,b.GbjectOidput; 
/** 

* The interface for those classes that serialize objects to and from 

* a stream, lie object that inylements this interface should write 

* just the objects attributes, not any other descrptive information 

* about the object Typically, a <code>SeriaBzerIF</code> knows how 

* xo serialize a specific class. 
*/ 

public interface SerializerJF { 
/** 

* Reads an object from the stream 
* 

* @return The object that was read. 

* {ajparam in the input stream containing the object 

* ©exception java.b JOExceptbn thrown if the stream foils 

* ©exception jaw.lan&ClassNotFoundException thrown if the steam 

* fails 
*/ 

Object readOtyectfObjectliput in) throws IOException, CkssNotFoundExceptxx 

* Writes the given object to the stream 

* @param out the output stream into which the object will be written 

* @param element the object that will be written to the stream 

* ©exception java.b .IOException thrown if the stream feils 
*/ 

void writeObject(ObjectOutput out, Object element) throws IOException; 



package comibmjtcxserklizatbn; 

import Java. k> t *; 
import java.math.BigIntegpr; 
import java.math.BigDecimal; 
import java,utiLDate; 
import java.utiLGregprknCalendai; 
import java.utilHashtable; 
import java.utilS imp leTimeZone; 
inport java.utiiStringTokenizer; 
import java.utilTimeZone; 
inport java. util Vector; 

* The <code>SeriaIizerIF</code> that is used as the base level 

* serializes It contains three tables used to serialize objects: 

* <brxu> 

* <1> codeTable: the table containing die serialization code of 

* an object based on the name of the class 

* <li> nameTable: the table containing the name of the class 

* based on the serialization code 

* <li> serializationTable: the table containing the serializer of 

* of an object based on its serialization code 
*<Ai> 

* <br><br> 

* <code>BaseSerializer</code> delegates the responsiblity of 

* serializing the objects to the <code>SeriaIizerIF</code> associated 

* with that class or to the object itself if it implements 

* <code>ExtermEzabfe</code>. 
*/ 

public class BaseSerializer implements SerializerIF { 
static private final int NULL_OBJECT = 0; 
static private final int OTHER = QxOOfF, 

static private final String HASHTABLE_SER = ^lassNameHaskser"; 
static private final String INI_FILE = ^lassNarass.ini"; 

static private Hashtable codeTable - null; 
static private Hashtable nameTable = null; 
static private Hashtable serializerTable = null; 
static private BaseSerializer instance = null; 
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class BigDecimaBerializer inplements SerklizerBF { 

public Object readObject(ObjectIi]put in) flirows CkssNofFourdExceptbn, IOException { 



int scale - iareadShortO; Fig U TB 110 

int size = iareadShortO", 
byte[] bytes = new byte[size]; 

iareadFully(bytes); 1 1 000 

pg2 

BigTnteger temp = new Big[ntegpr(bytes); 
return new BigDecimal(temp, scale); 

} 

public void writeGbject(ObjectOutput out, Object element) throws IOException { 
BigDecimal bigD = (BigDecimal)element; 

int scale = bigD.scaleO; 
bigD.se tScafe(0); 

byteQ bytes = bigD. toBigInteger().ioByteAriayO; 
bigD.setScafe(scafe); 

out. writeS hort(scale); 

out, writeShort(bytes, length) ; 

out.write(bytes); 

} 

} 

class BiglntegerSerializer in^lements SerializerIF { 

public Object readObject(Objectlnj>ut in) throws CkssNotFoundExeeption, 10 Exception 

{ 

int size = iareadShortO; 
byteQ bytes = new byte[size]; 
inreadFully(bytes); 

return new Biglnteger(bytes); 

} 

public void writeObject(ObjectOutput out, Object element) throws IOException { 
byteQ bytes = ((BigInteger)eIenKnt).toByteArrayO; 

out. writeS hort(bytes. length); 
out.write(bytes); 

} 

} 

class BoofeanSerializer implements SerializerIF { 

public Object readObject(ObjectIiput in) throws ClassNotFoundException, IOException 

int value = iareadByteO; 

return (value = 1) ? BooleanTRUE : BoofeaaFALSE; 

} 

public void writeObject(ObjectOutput ou^ Object ekntent) throws IOException { 
outwriteByte(((Boolean)efement).boobanValueO ? 1 : 0); 

} 
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class ByteSerializer implements SeralizerlF { 

public Object ieadObject(ObjectInput in) throws ChssNotFoundException, IOException { 
byte value = in.readByte(); 

return new Byte( value); 

} 

public void writeObject(ObjectOutput out, Object element) throws IOException { 
out.writeByte(((Byte)element).byt3eValue0); 

} 

} 

class ChaEscterSerializcr implements SerializerIF { 

public Object readObject(ObjectInput in) throws CkssNotFoundExccption, IOExceptkm { 
char value - iateadCharO; 

Teton new Character(vahie); 

} 

public voil writeObject(ObjectOutput out, Object element) throws 10 Exception { 
outwriteCbar(((Character)elen3ent)xharValueO); 

} 

} 

class DateSerializer inplements SerializerIF { 

public Object teadObject(ObjectIiput in) throws ClassNolFoundException, IOException { 
kmg value = inreadLongO; 

return new Date(TOlue); 

} 

public void writeObject(ObjectOutput out, Object element) throws IOException { 
out writeLong(((Date)eIeirent). getTimeO) ; 

} 

} 

class DoubteSerializer implements SerializerIF { 

public Object readObject(OhjectInput in) throws CbssNotFoundExceptbn, IOExceptkm { 
double value ~ inreadDoubleO; 

return new Double(value); 

} 

public void writeObject(ObjectOutput out, Object element) throws IOException { 
outwiteDoubfe(((Doiibfe)elen3ent).doubleValueO); 

} 
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class FbatSerializer implements SerializerIF { 

public Object readObject(ObjectIiiput in) Ihrows ClassNotFoundExceptfon, IOExceptkm { 
float value = iaieadFtoatO; 

return new Fk>at( value); 

} 

public void writeObject(ObjeclOutput out, Object element) throws IOExceptkm { 
out.writeFbat(((Fbat)el6iiiBiit).fbatValueO); 

} 

} 

class GtegoriauCalendarSetializer implements SerializerIF { 

public Object readObject(ObjectInput in) flnows CbssNofFoundExceptbn, IOExceptbn { 
bng time = iareadLongO; 
Date date = new Date(time); 
SerializerIF serializer = BaseSerializer.getlnstanceO; 
TimeZone tz - (TimeZone)serializer.readObject(in); 

GregorianCafendar gCalendar = new GregorianCafendarftz); 
gCabndar.setTime(date); 

return gCalendar; 

} 

public void wriieGbject(ObjectOutput out, Object element) throws IOExceptbn { 
Gre gpr ianCale ndar temp = (GiegoranCatetriar)eleinent; 

Date date = temp.getTimeQ; 
TimeZone tz = tenp.getTtmeZoneQ; 

out. wrteLong(date. getTime()); 

SerializerIF serializer = BaseSerializer.getlnstanceO; 

serializer. writeObjecttput, tz); 

} 

} 

class IntegerSerializer implements SerializerIF { 

public Object readObject(ObjectInput in) throws ClassNofFoundExceptbn, IOExceptbn { 
int value = inreadlntQ; 

return new Integer( value); 

} 

public void writeObject(ObjectOutput out, Object element) throws lOException { 
out writelnt(((ln1ieger)e Iement).intValue()); 

} 

} 

class LongSerializer implements SerializerIF { 

public Object readObject(ObjectInput in) throws ClassNotFoundExceptbn, IOExceptbn { 
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return new Long(vahie); 

} 

public void writeObject(ObjectOutput out, Object element) throws lOException { 
outwritelx>ng(((Long)elenient).bngValueO); 

} 

class ObjectArraySerializer implements SerializerlF { 

public Object teadObject(ObjectIi]pui m) throws CkssNotFoundException, lOException { 
int size = inreadShortQ; 

Objectf] array = new Object[size]; 
for (int i = 0; i < size; rH-) { 

SerializerlF serializer = BaseSeriali2er.getInstance0; 
anayfi] ^ serializer.readObject(in); 

return array; 

} 

public void write0bject(0bjec1Oulput out, Object element) throws lOException { 
Object]] array = (Object0)elenient; 

out writeS hort(anay. length); 

for (int i = 0; i < array.length; { 

SerializerlF serializer = BaseSerializer.getlnstanceO; 

serializer. writeObjec^out, arravfi]); 

} 

} 

} 

class ObjectSerializer implements SerializerlF { 

public Object readObject(ObjectInput in) ihrows CbssNotFoundException, lOException { 
return iareadObjectO; 

} 

public void writeObject(ObjeclQu1put out, Object element) throws lOException { 
outwriteObjectfclemsnt); 

} 

class ShortSerializer inplements SerializerlF { 

public Object readObject(ObjectIiput in) throws CbssNotFoundException, lOException { 
short value = inreadShortQ; 

return new Short(value); 
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public void writeObject(ObjectOutput out, Object element) throws lOException { 
outwriteShort(((Short)elemert).shortVaIueO); 

} 

} 

class SirripleTimeZo ncSerializer implements SerializerIF { 

public Object ieadObject(ObjectInput in) throws ChssNotFoundExceptbn, lOException { 
int offset = iareadlntO ; 

SemlizcrIF serializer = BaseSerializer.getlnstaireO; 
String id = (String)serializer.readObject(in); 

return new SinpleTimeZone(offset, id); 

} 

public void writeObject(ObjectOutput out, Object element) throws lOException { 
SimpleTimeZone temp = (SinpleTimeZoiie)efement; 

out writelnt(tenp. getRawO ffiet()); 

SerializerIF serializer = BaseSerializergetInstance0; 

serializer. writeObjecKout, tenp.getlDO); 

} 

} 

class StringSerklizer tenements SerializerIF { 

public Object readObject(ObjectIiput in) throws CbssNotFoundException, lOException { 
int size = in.readShort(); 
byte[] bytes = new byte[size]; 
in readFully (bytes) ; 

return new String(bytes); 

} 

public void writeObject(ObjectOutput out, Object efeirent) throws lOException { 
byteQ bytes = ((Strmg)efement).gstBytesQ; 

out writeS hort(bytes. length) ; 
outwrite(bytes); 

} 

} 

class VectorSerklizer implements SerializerIF { 

public Object ieadObject(ObjectlEput in) throws CkssNofFoundException, lOException { 
int size = iareadShortO; 

Vector vector = new Vector(si2e); 
for (int i = 0; i < si2e; if+) { 

SerializerIF serializer - BaseSerializer.getlnstanceQ; 

vector.addElemeiit(seriali2er.TeadObjec^in)); 
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return vector, 

} 

public void writeObject(ObjectOutput out, Object element) throws IOException { 
Vector tercp = (VectoT)e!ement; 

Objectf] array - new Object[tenp.size01; 
for (int i = 0; i < array.fength; rH-) { 
arrayfi] - teiqxefementAt(i); 

} 

out writeShort(array. length); 

for (int i « 0; i < airay.fength; if+) { 

SerklizerLF serializer ~ BaseSerializer,getInstanceO; 

serializes writeObjec^out, array[i]); 

} 

} 

} 

* Deiault constructor. The constructor is private because this is a 

* singleton class. When the object is constructed, it initializes its 
" tables. 

*/ 

private BaseSerializer0 { 
initO; 

} 

/** 

* Adds tbe given elements to the three tables. 

* @param className the name of tte class 

* @param code the code for the given class 

* @param serializer the object responsible for serializing the given 

* class 
*/ 

private void addDataToTables(String dassName, Nuniber code, SeriaHzerlF serializer) { 
getCodeTableQ.put(code, className); 
gptNameTableO.pu^className, code); 

if (serializer != null) { 

getSerializerTableO.pu^code, serializer); 

} 

} 
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* Creates the codes aid serialize objects for the de&ult serialization 

* classes and adds them to the tables. The tables are then written to 

* a serialized file. 
*/ 

private void creatieDefaultTablesO { 

addDataToTabfes(BigDecimaiclass.getNanieO, new Byte((byte)l), new 
BigDec imalSerializerQ) ; 

addDataToTabfes(BigJntegerxlass.getKain&Oj rew Byfe((byte)2), new BiglntegsrSerializerO); 

addDatoToTabfcs(Booleaaclass.getNaine0 3 new Byte((byte)3), new BoofeanSerializerO); 

addDataToTabfes^yte.class.gplNameO, sew Byte((byte)4) 3 new ByteSerializerO); 

addDataToTabfestChacactet.dass.ge^NameO^ raw Byte((byte)5), new CharacterSerializeiQ); 

addDataToTables(Date.class,gefNanieO J new Byte((byte)6), new DateSerializer()); 

addDataToTabfes(Double.cbss.getNaneO. new Byte((byte)7), new DoubleSerializerQ); 

addDataToTabfes(Fbatchss.gelNatneO > raw Byte((byte)8)» new FfoatSeriaHzerQ); 

addDataTo Tab les(GregorianCaIendar.c lass. getNameO, new Byte((byte)9)> new 
GregprianCafendarSerializerO); 

addDataToTabfcsCIntegirxhss.getN&meO, new Byte((byte)10), new IntegerSerializer0); 

addDataToTabbs(LoTig.c]ass.gstNaroe() ? new Byte((byte)ll), newLongSerializerO); 

addDataToTabfcs(ShorLclass.getName()> new ByteCOyte)!!), new ShortSerializerO); 

addDataToTabfes(SinpleTimeZore^^ new Byte((byte)13) s new 

Simple TimeZoneSerializerO); 

addDataToTabfcs(String.class,82tNameO > newByfe((byte)14), new StringSerializer0); 

addDataToTabfes(Vector.class^tNan^0 5 raw Byts((byte)15), new VectorSerializer0); 

addDataTo Tab les(Objectc lass. getNameO> new Byt»((byte)16), new ObjectSerializer()); 

writeTabfesO; 

} 

/** 

* Returns an instance of the table of class names, keyed by their code. 

* If the table does not exist, it is created. 

* @return The table of class names. 
*/ 

protected Hashtabfe getCodeTable0 { 
if(codeTabfe = null) { 

codeTabte = new Hashtable0; 

} 



return codeTabfe; 

} 

* Returns m instance of <code>BaseScrializer</code>. 

* @return An instance of <code>BaseSerializer</code>. 
*/ 

public static SerializerIF getlnstanceO { 
if (instance = null) { 

instance ~ new BaseSerializerQ; 

} 

return instance; 

j 

/** 

* Returns an instance of the table of codes, keyed by their 

* corresponding class name. 

* If the table does not exist, it is created. 

* @xeturn The table of codes. 
+/ 

protected Hashtabfe getNameTabfe() { 
if (nameTable — null) { 

nameTable = new Hashtabfe 0; 

> 

return nameTable; 

} 

* Returns an instance of the table of serializers, keyed by tteir 

* corresponding code. 

* If the table does not exist, it is created, 

* @return The table of class names. 
V 

protected Hashtabfe gstSerializerTabfeQ { 
if (serklizerTable = null) { 

serklizerTable new Hashtable(); 

} 

return serklizerTable; 

* Initializes the hashtable from either a serialized hashtabfe or from 

* an ini file. 
*/ 



protected void initQ { 

File seralizedFile - new Ffle(HASHTABLE_SER); _ . . 

File iniFile = new Fife(MJFILE); FigUrG I 

if (serializedFile.existsO) { 

readSeralkedFile(serializedFile); 1 1 00° 

} efce { P9 10 

if (iniFile.existsO) { 

readlniFile(iniFile); 

} 



createDefaultTabtesO; 



} 



* Gets the value of the serialization code from the table based on 

* the classNatne provided, The value returned can either be a 

* <code>Byte</code> or an<code>Mtegpr</code>. The return value 

* will be a <code>Byte</code> if tbe className is one of the base 

* data types. 

* @return The serialization code of the className. 

* @param className the name of the class 

>7 

private Number tookupCode(String classNatne) { 
Nuirber code = null; 



if (className != null) { 

code = (Number) @3tNfameTable0.get(classNaTne); 

} 

return code; 

} 

* Looks up the hashcode in the table and returns the String value of 

* fiie hashcode. If the hashcode does not exist in the table 

* <code>nulK/code> is returned. 
* 

* @return The object that was stored in the table with the given 

* hashcode. 

* @param hashcode the hashcode that will be used to bok up the value 
V 



private Siring kx>kupName(Nuni>er code) { 
String ckssName = null; 

if (code != null) { 

chssName = (String)getCodeTabteO-get(code); 

} Figure 110 

return ckssName; 

} 

/** 11000 

* Defiult method comment P9 1 1 

* <P>PRE: 

* <P>POST: 

* ©return Parameter not modified 

* @return comiiajtcutiLSerializerlF 

* @param code int 
*/ 

private Seriaiizerff boki^Serializer(Nun±ier code) { 
SerializerJF serializer = null; 

if (code hnull) { 

serializer = (SerializerIF)gelSerializerTableO-8^(code); 

return serializer; 

* De&ult method comment. 
* 

* <P>PRE: 

* <P>POST: 

* ©return Parameter not modified 

* @param iniFile java.io.FiIe 
*/ 

private void readIniFile(File iniFile) { 
BuffeiedReader in = null; 

try{ 

in - new BufferedReader(iiew FileReader(iniFile)); 

for (String inLine = inreadLineO; inLine I- null; inLine - iareadLine()) { 
String trimLine = inLine.trim(); 



if ((trimLine.length0 > 0) && 

!trimLine.startsWitl< , W 1, )) { 

StringTokenizcr tokenizer = new StringTokeni2ei(triinLine); 

String className = tokenizer. nextToken(); 
Integer code = new Integer(className,hashCodeO); 
SerializerlF serializer = null; 

if (tokenizer.hasMoreTokensO) { 

String serklizerNarae = tokenizer.nextTokenO; 

try{ 

serializer = (SerhlizerIF)Class>&rNaine^ 
} catch(Exceptim e) { } 

} 

addDataToTabfes(classNaire, code, serializer); 

} 

} 

} catch (Exception thro wA way) { 
} finally { 

*y{ 

in.cbse0; 
} catch (Exception thro wA way) { 

} 
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* Reads the object from (he stream by first reading the code for the 
:J! * efemsnt then reads the appropriate data for that object 



@retura The object that was read from the stream. 
* @param in the iiput stream that contains the object 

public Object iead0bject(0bjectli93ut in) 

throws ClassNotFoundExceptbn, IOExeeption { 
Object retVal = nuH; 
Number code = null; 

b}te baseCode = inreadByteQ; 



if (baseCode == NULL_OBJECT) { Figure 110 

retVal = nuH; 

} eke { 

if (baseCode != OTHER) { 1 1 000 

code = new Byte(baseCode); pg 1 3 

}else{ 

int secondCode = iareadlntQ; 
code = new Inieger(secondCode); 

SerializerIF serializer = IookupSeralizer(code); 
if (serializer != null) { 

retVal = serklizer.readObjeet(in); 

}else { 

String className = taokupNaire(code); 
try{ 

retVal - CIass.fi)rNanK(className).newIrtstanceO; 

if (retVal instanceof Extermlizable) { 

((Externalizable)retVal).readExteraal(in); 

} else { 

retVal « iarcadObject(); 

} cateh(Exception e) { 
} 

} 

} 

return retVal; 

} 

/** 

* Rsads the file containing the serialized hashtabfes of data 
* 

* (gparam serializedFile the file containinig the serialized tables 
*/ 

private void readSerializedFileCFile serklizedFile) { 
Objectlnp utS tream in = null; 
try{ 

in - new ObjectlnputS tream(new F ilelnputS tream(seria lizedF ile)> ; 
codeTable = (Hashtable)in.readObject(); 
nameTable = (Hashtabfe)iareadObject0; 
serializerTable = (Hashtable)in.TeadObject0; 



} catch (Exception throwAway) { 
} finally { 
try{ 

incbseO; 
} cateh (Exception throwAway) { } 
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if((codeTable==null)|| 

(BameTabte==null)|| 
(seraBzerTable = null)) { 



createDefeultTablesO; 



} 



} 



} 



* Writes the given object to the stream. First, the code representing 

* fee type of the object is written, then the data within the object 

* is written. 



* (a param out the output stream that will contain the object 

* @ param element the data object that will be written 
*/ 

public void writsObject(ObjectOutput out, Object element) 
throws IOException { 

if (element = nufl) { 

outwriteByteOSftILL_OBJECT); 

} else { 



String chssName = element getClass().getNameCfc 
Number code = fookupCode(className); 

if (code != null) { 

if (code instanceof Byte) { 

out writeByte(code.byte Value 0); 
} else if (code instanceof Integer) { 

out. writeByte(OTHER) ; 

out write!nt(code. int ValueQ) ; 



SeriahzerlF serklker = bokupSerializer(code); 

if (serializer != null) { 

serialiaer.writeObjecKout element); 
} else if (element instanceof Externa lizable) { 

((Extemlizable)elernent).writeExternal(out); 



* 



} 
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}else{ 

out.writeObject(element); 

} 

}else { 

if (efementimtanceofObject[]) { 

classNams =ObjectQ.class.getNaTix0; 

} else { 

className - ObjectcIass.getNanie(); 

} 

code = fookupCode(ckssNanie); 

SerializerIF serklizer = fookupSerializer{code); 

outwriteByte(code.byteValueO); 
seralizer.witeObject(out; element); 

} 

} 

} 

/** 

* Writes the tabfes to the file. 
*/ 

private void writeTablesQ { 

ObjectOutputStream out = null; 

try{ 

File serFfle - new Fils(HASHTABLE_SER); 

out = new ObjectOutputStream(new FfleOutputStream(serFile)); 

out.writeObject(geCodeTableO); 

out.writeObject(getNanieTab]e()); 

out. writeObjec t(getSerklizerTabfe()); 

outwriteObject(iiew DateO); 
} catch(Exception e) { 
} finally { 

try { 

outcfoseO; 
} catch(Exception e) { } 

} 

} 
} 
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DOCKET NUMBER: AT9-99-33 9 
DECLARATION AND POWER OF ATTORNEY FOR 
PATENT APPLICATION 



As a below named inventor, I hereby declare that: 

My residence, post office address and citizenship are as stated below 
next to my name; 

t I believe I am the original, first and sole inventor (if only one name 
is listed below) or an original, first and joint inventor (if plural names are 
listed below) of the subject matter which is claimed and for which a patent is 
sought on the invention entitled 

MECHANISM FO R CROSS C HANN E L M ULTT -STIVER MULTI - PROTOCOL MU LT I - DATA MQTTRTt THTN 
CLIENTS 

the specification of which (check one) 

X is attached hereto. 

was filed on 

as Application Serial No. 

and was amended on 

(if applicable) 

I hereby state that I have reviewed and understand the contents of the above 
identified specification, including the claims, as amended by any amendment 
referred to above. 

I acknowledge the duty to disclose information which is material to the 
patentability of this application in accordance with Title 37, Code of Federal 
Regulations, §1.56 . 

I hereby claim foreign priority benefits under Title 35, United States Code, 
§119 of any foreign application (s) for patent or inventor's certificate listed 
below and have also identified below any foreign application for patent or 
inventor's certificate having a filing date before that of the application on 
which priority is claimed: 

Prior Foreign Application (s) : Priority Claimed 



(Number) (Country) (Day /Month/Year) 



I hereby claim the benefit under Title 35, United States Code, §120 of any 
United States application (s) listed below and, insofar as the subject matter 
of each of the claims of this application is not disclosed in the prior United 
States application in the manner provided by the first paragraph of Title 35, 
United States Code, §112, I acknowledge the duty to disclose information 
material to the patentability of this aoplication as defined in Title 37, code 
of Federal Regulations, §1.56 which occurred between the filing dat;e of the 
prior application and the national or PCT international filing date of this 
application: 



(Application Serial #) (Filing Date) (Status) 
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DOCKET NUMBER: AT9-99-3 3 9 



I hereby declare that all statements made herein of my own knowledge are true 
and that all statements made on information and belief are believed to be 
true; and further that these statements were made with the knowledge that 
willful false statements and the like so made are punishable by fine -or 
imprisonment, or both, under Section 1001 of Title 18 of the United States 
Code and that such willful false statements may jeopardize the validity of the 
application or any patent issued thereon. 

POWER OF ATTORNEY: As a named inventor, I hereby appoint the following 
attorneys and/or agents to prosecute this application and transact all 
business in the Patent and Trademark Office connected therewith. 

John W. Henderson, Jr., Reg. No. 26, 907; Thomas E. Tyson, Reg. No. 23,543 
James H. Barksdale, Jr., Reg. No. 24,091; Casimer K. Salys, Reg. No. 28,900 
Robert M. Carwell, Reg. No. 28,499; Douglas H. Lefeve, Reg. No. 26,193 
Jeffrey S. LaBaw, Reg. No. 31,633; David A. Mims, Jr., Reg. 32,708; Volei 
Emile, Reg. No. 39, 969 ; Anthony v. England, Reg. No. 35, 129; Leslie A. van 
Leeuwen, Reg. No. 42,196; Christopher A. Hughes, Rea. No. 26,914; Edward A. 
Pennington, Reg. No. 32,588; John E. Hoel, Reg. No. 26,279; Joseph C. Redmond, 
Jr., Reg. No. 18,753; Marilyn S. Dawkins, Reg. No. 31,140; Duke" w. Yee, Reg. 
No. 34,285; Mark E. McBurney, Reg. No. 33,114; and Colin P. Cahoon, Reg. No. 
38,836; Joseph R. Burwell, Reg. No. P-44,468; Rudolph J. Buchel, Reg. No. 
43,448; Stephen R. Loe, Reg. No. 43,757. 

Send correspondence to: Duke W. Yee, Carstens, Yee & Cahoon, LLP, P.O. Box 
802334, Dallas, Texas 75380, and direct all telephone calls to Duke w. Yee, 
(972) 362-2001. 



FULL NAME OF SOLE OR F I r/t/ INVENT : ^Peter C. Bahrs 
INVENTORS SIGNATURE 



^^/6cU/y^ DATE : ?/?/&? 



RESIDENCE : 11250 Taylor Draner Lane #124 

Austin, Texas 78759 
CITIZENSHIP: United States 
POST OFFICE ADDRESS: SAME AS ABOVE 

FULL NAME OF SECOND INVENTOR: Raphael Poole Chancev 
INVENTORS SIGNATURE: DATE- 
RESIDENCE : 12445 Alameda Trace Circle Apt. #824 

Austin, Texas 78727 
CITIZENSHIP: United States 
POST OFFICE ADDRESS: SAME AS ABOVE 
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PULL NAME OF THIRD INVENTOR: Barrv Alan Feiaenbaum 

INVENTORS SIGNATURE: DATE: 

RESIDENCE: 11131 Callanish Park Drive 

Austin, Texas 78750 
CITIZENSHIP: United States 
POST OFFICE ADDRESS: SAME AS ABOVE 

FULL NAME OF FOURTH INVESTOR: Manish Mahesh Modh J / 
INVENTORS SIGNATURE: / r Ahn%tf y ^^^jy^fi\ DATE : 7 1 1/9 f 



RESIDENCE: 16822 Ba^Tev Jean Drivfi 

Round Rock, Texas 78 681 y 
CITIZENSHIP: -to&U 

POST OFFICE ADDRESS: SAME AS ABOVE 
FULL NAME OF FIFTH INVENTOR: Sean Michael^Sundbera 



INVENTORS SIGNATURE: >W / A ,J S^/^XU DATE: ^) / ^ / "1 1 



RESIDENCE: 1211 Wood Creek /j 

Cedar Park, Texas 78613 
CITIZENSHIP: United States 
POST OFFICE ADDRESS: SAME AS ABOVE 

FULL NAME OF SIXTH INVENTOR: John Allen Hubert Wool f rev 

INVENTORS SIGNATURE: DATE : 

RESIDENCE : 4064 Farnsworth Crescent 

Mississauga, Ontario, Canada L5L 3Z3 
CITIZENSHIP: Canada 

POST OFFICE ADDRESS: SAME AS ABOVE 
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DOCKET NUMBER : AT9 - 9 9 - 3 3 9 
DECLARATION AND POWSR OF ATTORNEY FOR 
PATENT APPLICATION 



As a below named inventor, I hereby declare that: 

My residence, post office address and citizenship are as stated below 
next to my name; 

I believe I am the original, first and sole inventor (if only one name 
is listed below) or an original/ first and joint inventor (i£ plural names are 
listed below) of the subject matter which is claimed and for which a patent is 
sought on the invention entitled 

MECHANISM FOR CROSS CHANNEL MOLTT- SERVER MtlLTX- PROTOCOL MULTI-DATA MODEL THIN 
CLIENTS 

the specification of which (check one) 

x is attached hereto. 

was filed on 

as Application Serial No. 

and was amended on 

(if applicable) 

I hereby state that I have reviewed and understand the contents of the above 
identified specification, including the claims, as amended by any amendment 
referred to above. 

I acknowledge the duty to disclose information which is material to the 
patentability of this application in accordance with Title 37, code of Federal 
Regulations, §1.56. 

I hereby claim foreign priority benefits under Title 35, United States Code, 
§119 of any foreign application is) for patent or inventor's certificate listed 
below and have also identified below any foreign application for patent or 
inventor's certificate having a filing date before that of the application on 
which priority is claimed; 

Prior Foreign Application (s) : Priority Claimed 

Yes No 

(Number) (Country) (Day /Month/Year) 



I hereby claim the benefit under Title 35, United States Code, §120 of any 
United States application (s) listed below and, insofar as the subject matter 
of each of the claims of this application is not disclosed in the prior United 
States application in the manner provided by the first paragraph of Title 35, 
United States Code, §112, I acknowledge the duty to disclose information 
material to the patentability of this application as defined in Title 37, Code 
of Federal Regulations, §1.56 which occurred between the filing date of the 
prior application and the national or PCT international filing date of this 
application: 



(Application Serial #) (Filing Date) (Status) 
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DOCKET NUMBER: AT9-99-339 



I hereby declare that all statements made herein o£ my own knowledge are true 
and that all statements made on information and belief are believed to be 
true; and further that these statements were made with the knowledge that 
willful false statements and the like so made are punishable by fine or 
imprisonment, or both, under Section 1001 of Title 18 of the United States 
Code and that such willful false statements may jeopardize the validity of the 
application or any patent issued thereon. 

POWER OF ATTORNEY: As a named inventor, I hereby appoint the following 
attorneys and/or agents to prosecute this application and transact all 
business in the Patent and Trademark Office connected therewith. 

John w. Henderson, Jr., Reg. No. 26,907; Thomas E. Tyson, Reg. No. 28, 543; 
James K. Barksdale, Jr., Reg, no. 24,091; Casimer K. Salys, Reg. No. 23,900; 
Robert M. Carwell, Reg. No. 28,499; Douglas H. Lefeve, Reg, No. 26,193; 
Jeffrey S. LaBaw, Reg. No. 31,633; David A. Mims, Jr., Reg. 32,708; vclel 
Emile, Reg. No, 39, 969 ; Anthony V. England, Reg. No. 35, 129 ; Leslie A. van 
Leeuwen, Reg. No. 42,196; Christopher A. Hughes, Reg. No. 26,914; Edward A. 
Pennington, Reg. No. 32,588; John E. Hoel, Reg. No. 26,279 ; Joseph C. Redmond, 
Jr., Reg. No. 18,753 ; Marilyn S. Dawkins, Reg. No. 31/140; Duke w. Yee, Reg. 
No. 34,285; Mark E. McBurney, Reg. No. 33,114; and Colin P. Cahoon, Reg. No. 
38,836; Joseph R. Burwell, Reg. No. P-44,463; Rudolph J. Buchel, Reg. No. 
43,448; Stephen R. Loe, Reg. No. 43,757. 

Send correspondence to: Duke w. Yee, Carstens, Yee & Cahoon, LLP, P.O. Box 
802334, Dallas, Texas 75380, and direct all telephone calls to Duke W. Yee, 
(972) 362-2001. 



FULL NAME OF SOLE OR FIRST INVENTOR: Peter C. Bahrs 

INVENTORS SIGNATURE: DATE:. 

RESIDENCE: 11250 Taylor Draper Lane #124 

Austin, Texas 78759 
CITIZENSHIP: United States 

POST OFFICE ADDRESS: SAMS AS ABOVE 

FULL NAME OF SECOND INVENTOR: Raphael Poole Chancev 

INVENTORS SIGNATURE: DATE: 

RESIDENCE; 12445 Alameda Trace Circle Apt. #824 

Austin, Texas 78727 
CITIZENSHIP; United States 
POST OFFICE ADDRESS: SAME AS ABOVE 
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DOCKET NUMBER: AT9 -99-339 

FULL NAME OF THIRD INV^jlTOK: Barrv Alat\ Feicenbaum 
INVENTORS SIGNATURE :_ 

RESIDENCE : 11131 Callanish Park Drive 

Austin, TWS 737$Q 
CITIZENSHIP: United States 

POST OFFICE ADDRESS: SAME AS ABOVE 

FULL NAME OF FOURTH INVENTOR: Manish Mahesh Modh 
INVENTORS SIGNATURE: DATE: 

RESIDENCE: 16622 Bailey Jean Drive 
Round Rock, Texas 78 681 
CITIZENSHIP : India 

POST OFFICE ADDRESS: SAMS AS ABOVE 
FULL NAME OF FIFTH INVENTOR: Sean Michael Sundberg 

INVENTORS SIGNATURE: DATE: 

RESIDENCE: 1211, WQQd CCSeK 

Cedar Park, Texas 78613 
CITIZENSHIP: United States 

POST OFFICE ADDRESS: SAME AS ABOVE 

1 

1 

FULL NAME OF SIXTH INVENTOR: John' Allen Hubert Wool£rev 

INVENTORS SIGNATURE: ; DATE : 

RESIDENCE : 40 64 Farnsworth Crescent 

Mig Si s s fruqa, Ontar io r Cftnafla L5L 3Zj 

CITIZENSHIP: Canada 

POST OFFICE ADDRESS: SAMS AS ABOVE 
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DOCKET NUMBER: AT9-99-33 9 

DECLARATION AND POWER CP ATTORNEY FOR 
PATENT APPLICATION 



As a below named inventor, I hereby declare that: 

My residence, post office address and citizenship are as stated below 
next to my name; 

I believe I am the original, first and sole inventor (if only one name 
is listed below) or an original, first and joint inventor (if plural names are 
listed below) of the subject matter which is claimed and for which a patent is 
sought on the invention entitled 

MSgHAHTSM PGR gROSS gHAKWBT. M T TT^T - SERVER MPTiTT .PROTOCOL MULTI-DATA MOPKIi THIN 
CLIENTS 

the specification of which (check one) 

is attached hereto. 

was filed on 

as Application Serial No- - 

and was amended on , 

{if applicable) 

I hereby state that I have reviewed and understand the contents o£ the above 
identified specification, including the claims, as amended by any amendment 
referred to above. 

I acknowledge the duty to disclose information which is material to the 
patentability of this application in accordance with Title 3?, Code of Federal 
Regulations, SI. 56. 

I hereby claim foreign priority benefits under Title 35, United States Code, 
§119 of any foreign application (s> for patent or inventor's certificate listed 
below and have also identified below any foreign application for patent or 
inventor's certificate having a filing date before that of the application on 
which priority is claimed: 

Prior Foreign Application (s) : Priority Claimed 

Yes No 

(Number) (Country) (Day/Month/Year) 



I hereby claim the benefit under Title 35, United States Code, §120 of any 
United States application (s) listed below and, insofar as the subject matter 
of each of the claims of this application is not disclosed in the prior united 
States application in the manner provided by the first paragraph of Title 35, 
united States Code, §112, I acknowledge the duty to disclose information 
material to the patentability of this application as defined in Title 37, Code 
of Federal Regulations, §1.56 which occurred between the filing date of the 
prior application and the national or PCT international filing date of this 
application: 



(Application serial #) (Filing Date) (Status) 
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DOCKET NUMBER: AT9-99-339 



I hereby declare that all statements made herein cf my own knowledge are true 
and that all statements made on information and belief are believed to be 
true; and further that these statements were made with the knowledge that 
willful false statements and the like so made are punishable by fine or 
imprisonment, or both, under Section 10 01 of Title 18 o£ the United States 
Code and that such willful false statements may jeopardize the validity of the 
application or any patent issued thereon. 

POWER OP ATTORNEY: As a named inventor, I hereby appoint the following 
attorneys and/or agents to prosecute this application and transact all 
business in the Patent and Trademark Office connected therewith. 

John W. Henderson, jr., Reg. No. 2S,9C7; Thomas E. Tyson. Reg. No, 28,543; 
James H. Barksdale, Jr., Reg. No. 24, 091; casimer K. Salys, Reg. no« 23,900; 
Robert M, Carwell, Reg. No. 28,499; Douglas H. Lefeve, Reg- No. 26,19 3; 
Jeffrey S. LaBaw, Reg. No. 31, 533; David a, Mims, Jr., Reg. 32,708; Volel 
smile, Reg. No. 39,9S9; Anthony V. England, Reg. No. 35,129; Leslie A. van 
Leeuwen, Reg, No. 42,195; Christopher A. Hughes, Reg. No. 2€,914; Edward A. 
Pennington, Reg- No. 32,538; John E. Hoei, Reg. No. 2S,27S; Joseph C. Redmond, 
jr., Reg. NO. 18,753; Marilyn s* Dawkins, Reg. no. 31,140; Duke w. yee, Reg. 
No. 34,285; Mark E. McBurney, Reg, No. 33,114; and Colin P. Cahoon, Reg. No. 
38/836; Joseph X. Burwell, Reg. no. P-44,4S3; Rudolph J. Suchel, Reg. No. 
43,448; Stephen R. Loe, Reg, No. 43, 757. 

Send correspondence to: Duke w. yee, cars tens, Yee & cahoon, LLP, P.O. sox 
802334, Dallas, Texas 75380, and direct all telephone calls to Duke W. Yee, 
{972) 362-2001. 



FULL NAME OF SOLE OR FIRST INVENTOR: Peter C. Bahrs 

INVENTORS SIGNATURE: DATE: 

RBSIDENCSi 1125 0 Tavlor Draper Lane #124 

CITIZENSHIP: United States 

POST OFFICE ADDRESS; gAMS AS ABOVE 



PULL NAME OF SECOND INVENTOR: Raphael Poole Chancsv 

INVENTORS SIGNATURE: , DATE: 

RESIDENCE: 12445 Alam eda Trace Circle Apt. #32d 

Austin. Tftxfrg 73777 

CITIZENSHIP: United States 

POST OFFICE ADDRESS; SAKE AS A30VS 
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DOCKET NUMBER; AT9-39-339 

PULL NAME OP THIRD INVENTOR: Sarrv Alan Feicenbaum 

INVENTORS SIGNATURE: DATS: 

RESIDENCE: 11131 Callanish Park Drive 

Austin, Texas 78750 
CITIZENSHIP; Unit&d Sfcatea 
POST OFFICE ADDRESS: SAME AS ABOVE 

PULL NAME OF POURTH INVENTOR t Man i ah Mahesh Mcdh 

INVENTORS SIGNATURE: DATE: 

RESIDENCE : 16822 Bailey Jean Drive 

R<?Mfld Rgg^c r Tgxag 78$8i 

CITIZENSHIP: India 

POST OFFICE ADDRESS: SAMS AS ABOVE 

FULL NAME 0? FIFTH INVENTOR: Sean Miche l Sundbern 

INVENTORS SIGNATURE: DATE: 

RESIDENCE: 1211 Wood Creett 

cgflar park, tbmr 1S£I2 

CITIZENSHIP: United States 

POST OFFICE ADDRESS: SAME AS ABOVE 

PULL NAME OF SIXTH INVENTOR: John Allen Hubert Woolfrav 

INVENTORS SIGNATURE: Q#jJ^kf^ 1 DATE! &*£+v»k* *S) 

RES IDENCE : 4064 Farnsworth Crescent 

MifiRjgaaiiga. Ontario. Canada L5L 17.1 
CITIZENSHIP: Canada 

POST OFFICE ADDRESS: SAMS AS ABOVE 
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